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用 可 


本 书 是 笔者 从 业 二 十 余年 、 从 事 图 书 创作 十 余年 的 工作 经 验 和 技 
术 积 标的 结晶 ， 是 对 十 余年 来 一 直 默 默 支 持 我 的 全 国 百 万 读者 的 真诚 
回馈 。 同 时 ， 本 书 也 是 笔者 这 十 多 年 来 付 诸 心 血 最 多 (整整 一 年 专职 
创作 时 间 ) 、 寄 予 希望 最 大 的 一 部 重头 之 作 ， 期 待 能 为 国家 的 计算 机 
网 络 专业 教育 尽 一 份 绢 薄 之 力 。 


为 什么 写 这 本 书 


其 实 很 久 以 前 就 有 了 写 这 本 书 的 动机 了 ， 但 由 于 我 深 知 写作 这 本 
书 的 难度 很 大 ， 再 加 上 自己 还 在 写作 其 他 图 书 ， 写 作 任务 一 直 非 常 党 
重 ， 所 以 就 耽误 了 。 不 过 ， 或 许 今 天 写 这 本 书 正 是 时 候 ， 一 则 笔者 又 
多 经 过 了 几 年 的 技术 学 习 和 工作 经 验 的 积累 ， 书 稿 的 质量 可 能 比 以 前 
更 高 ; 二 则 目前 计算 机 网 络 专业 越 来 越 边缘 化 了 ， 已 成 为 了 所 有 IT 人 
员 的 必修 课 ， 所 以 现在 对 要 求 有 一 本 高 质量 、 通 俗 易 懂 的 专注 于 计算 
机 网 络 原理 和 基础 知识 的 教材 的 呼声 比 以 前 更 高 了 。 综 合 起 来 就 是 以 
下 三 点 : 


1. 学 子 的 呼唤 : “和 零 基础 "不 应 只 是 一 名 宣传 口号 


计算 机 网 络 原理 和 基础 知识 类 的 课程 一 直 是 广大 计算 机 网 络 专业 
的 读者 最 头痛 的 一 门 诗 程 。 因 为 这 类 课程 不 仅 相 对 枯燥 乏味 ， 而 且 教 
材 中 的 技术 原理 解释 普遍 星 深 难 懂 。 也 正 因 如 此 ， 现 在 许多 计算 机 网 
络 专 业 的 大 学 生 ， 毕 业 后 仍 对 这 方面 的 知识 一 知 半 解 ， 走 上 工作 岗位 
后 过 到 实际 的 网 络 问 题 很 难 从 原理 方面 分 析出 故障 原因 ， 更 别 说 排除 
网 络 故障 了 。 


虽然 国内 这 方面 的 教材 非常 多 ， 也 不 乏 一 些 经 典 闭 作 ， 但 经 笔者 
分 析 后 认为 大 部 分 存在 这 样 或 那样 的 不 足 ， 要 么 通俗 性 较 壹 ， 要 人 么 内 
容 上 过 于 浅显 ， 更 多 的 是 照搬 理论 ， 难 以 使 网 络 专业 学 生 比 较 轻 松 地 
掌握 全 面 、 系 统 、 专 业 的 计算 机 网 络 原理 和 基础 知识 。 但 作为 一 名 老 
的 网 络 职业 工作 者 和 有 着 十 几 年 计算 机 网 络 专业 图 书 创作 经 验 的 老 作 
者 ， 深 知 这 样 一 本 看 似 非常 基础 ， 甚 至 有 一 些 人 认为 非常 侧 单 的 教 
材 ， 要 真正 写 出 水 平 、 写 出 权威 并 非 易 事 ， 特 别 是 在 通俗 性 方面 。 现 
在 许多 书 都 把 “ 零 基 础 ” 当 作 卖点 在 宣传 ， 但 真正 能 做 到 零 基础 ， 并 且 
在 内 容 上 有 一 定 深 度 的 书 却 并 不 多 见 。 


另外 ， 以 前 学 计算 机 网 络 原理 和 网 络 基 础 知识 的 人 可 能 大 多 数 是 
计算 机 网 络 专业 的 学 生 ， 但 随 着 计算 机 网 络 应 用 的 普及 ， 计 算 机 网 络 
知识 几乎 已 成 为 所 有 IT 专 业 必 修 的 基础 课程 。 而 那些 非 计算 机 网 络 专 
业 的 学 生 对 计算 机 网 络 可 以 说 是 真正 的 零 基 础 ， 所 以 对 这 类 教材 在 通 
俗 性 方面 的 要 求 会 更 品 。 要 把 那么 深奥 的 计算 机 网 络 原理 讲 得 能 让 这 


些 零 基础 的 读者 理解 和 接受 ， 难 度 吏 更 是 难以 想象 的 了 ， 这 点 笔者 在 
创作 过 程 中 深 有 体会 。 尽 管 笔者 在 这 方面 也 没有 过 深 的 造 放 ， 但 本 着 
对 信任 、 文 持 笔 者 的 百 万 读者 负责 ， 人 怀抱 着 百 万 读者 的 期 答 和 笔者 目 
己 二 十 多 年 的 学 习 和 工作 经 验 积 素 ， 伦 了 整整 一 年 全 职 的 创作 时 间 写 
下 了 这 本 笔者 认为 在 某 些 方面 ， 特 别 征 在 通俗 性 方面 有 所 提高 的 闭 
作 ， 力 争 使 零 基 础 的 网 络 “ 沫 乌 ? 也 能 轻松 掌握 复杂 、 深奥 的 计算 机 网 
络 原理 。 布 望 这 本 书 不 会 令 广大 读者 朋友 失望 。 


2. 时 代 的 变迁 : 不 懂 计 算 机 网 络 ， 你 不 敢 说 目 己 是 ITer 


如 果 十 年 前 你 听 到 同行 们 都 在 六 “ 不 介 计 算 机 ， 都 不 敢 说 目 己 是 
ITer*"， 那 么 十 年 后 的 今天 ， 你 所 听 到 的 一 定 束 是 “不 懂 计 算 机 网 络 ， 
都 不 好 意思 说 目 己 是 ITer”。 更 有 人 甚至 会 说 “不 懂 计算 机 网 络 ， 束 是 
现代 文 旱 ”。 这 些 观 点 虽然 可 能 有 些 偏 诺 ,但 也 足以 说 明 在 全 面 信息 化 
的 今天 ， 计 算 机 网 络 在 整个 IT 行业 的 重要 性 和 基础 性 ， 它 不 再 仅 是 网 
络 专业 人 士 必须 掌握 的 ， 所 有 ITer， 甚 至 所 有 现代 人 都 应 该 掌握 。 


以 上 虽然 看 似 口号 ， 但 却 实 实在 在 地 反映 了 当前 整个 IT 行业 都 是 
以 计算 机 网 络 作为 中 心 和 基础 平台 的 这 样 一 个 现状 。 十 年 前 ， 几 乎 所 
有 的 IT 开发 和 应 用 都 是 以 单一 的 计算 机 系统 为 平台 的 ， 几 乎 所 有 的 计 
算 机 程序 的 运行 环境 都 是 单 台 计算 机 。 十 年 后 的 今天 ， 随 着 互联 网 接 
入 的 普及 和 宽 市 接 入 速度 的 提高 ， 以 及 互联 网 和 企业 网 络 技 术 在 应 用 
上 的 普及 与 发 展 ， 一 切 都 发 生 了 变化 。 


过 去 单一 的 计算 机 系统 平台 根本 无 法 满足 当前 无 处 不 在 、 各 种 各 
样 的 网 络 应 用 需求 ， 绝 大 多 数 IT 开 发 和 应 用 平台 都 转向 了 计算 机 网 络 
这 个 无 边 的 大 平台 。 现 在 个 人 和 企 事业 单位 所 进行 的 各 项 IT 应 用 绝 大 
多 数 都 是 基于 计算 机 网 络 的 ， 如 浏 宽 网 页 、 收 发 邮件 、 写 博客 、 写 微 
博 、 网 上 购物 、 网 上 看 电影 /电视 、 网 上 玩 游戏 、 网 上 听 首 乐 、 网 络 电 
子 商 务 、 网 络 营 销 、 企 业 网 络 远 程 互联 、 网 络 会 议 、 网 络 直 播 等 。 似 
乎 我 们 现在 所 做 的 一 切 一 切 都 离 不 开 计算 机 网 络 ， 计 算 机 网 络 成 了 实 
实在 在 的 IT 计 算 中心 和 基础 应 用 平台 。 


现在 基于 单一 计算 机 系统 的 应 用 已 非常 少 了 ， 且 随 着 云 计算 、 物 
联网 这 样 的 新 型 网 络 技 术 的 应 用 和 普及 ， 可 以 十 分 清楚 地 预见 ， 计 算 
机 网 络 这 个 平台 才 是 整个 IT 行业 发 展 的 根本 。 束 连 现在 我 们 仍然 基于 
单机 操作 的 办 公 应 用 软件 ， 在 不 久 的 将 来 都 可 能 全 由 云 计算 服务 提供 
商 通过 互联 网 集中 提供 ， 再 加 上 迅猛 发 展 的 移动 互联 网 ， 计 算 机 网 络 
的 基础 地 位 将 得 到 进一步 巩固 。 到 那 时 ， 如 有 果 连 何 为 计算 机 网 络 都 不 
懂 ， 信 单 的 计算 机 网 络 故 障 排除 还 要 求助 于 人 ， 这 不 殊 古 现代 文 讲 
吗 ? 你 还 敢 说 你 是 ITerng? 


3. 职 业 的 挑战 : 计算 机 网 络 基础 原理 ， 网 络 职业 发 展 的 真正 瓶颈 


形势 摆 在 我 们 所 有 ITer 面 前 ， 但 国内 的 现状 却 不 怎么 令 人 满意 。 
先 且 不 说 所 有 IT 行业 ， 束 是 专门 从 事 网 络 管理 ， 或 者 网 络 工程 行业 的 
网 络 管理 员 和 网 络 工程 师 ， 在 计算 机 基础 原理 方面 能 比较 深入 地 说 出 


个 一 、 二 、 三 来 的 也 没 多 少 ， 碰 到 一 个 网 络 故 障 能 从 原理 上 进行 全 面 
} 析 的 人 更 是 少 之 又 少 ， 至 少 我 所 了 解 的 是 这 样 。 可 能 有 些 人 会 说 ， 
配置 和 管理 网 络 不 就 行 了 ? 他 们 认为 那些 深奥 的 基础 理论 没什么 

° 其 实说 这 样 话 的 人 还 是 不 是 很 届 得 网 络 管 理 和 网 络 工 程 的 真正 职 
不 是 很 理解 这 些 网 络 基 础 原理 的 本 质 和 重要 性 。 网 络 管理 的 主要 
职 贡 就 古 维护 ， 在 出 现 了 网 络 故 障 时 能 快速 、 准 确 地 排除 故障 ， 网 络 
工程 的 主要 职员 就 古 为 用 户 设 计 一 个 实用 、 符 合 各 项 标准 ， 且 稳定 的 
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很 难 想象 ， 一 个 网 络 基础 理论 不 扎实 的 网 络 管理 人 员 如 何 能 快 
速 、 准 确 地 进行 网 络 故障 分 析 和 排除 ， 网 络 工程 人 员 又 如 何 能 设计 出 
一 个 符合 标准 、 符 合用 户 应 用 需求 且 能 长 时 间 保持 稳定 的 系统 。 对 于 
从 事 各 种 网 络 应 用 程序 开发 的 程序 员 们 来 说， 网 络 基础 理论 同样 非常 
重要 ， 一 个 不 懂得 网 络 体系 结 构 ， 以 及 各 层 功能 实现 原理 和 应 用 接口 
的 程序 员 ， 怎 么 可 能 设计 出 一 个 符合 对 应 网 络 应 用 标准 的 应 用 程序 ? 
又 起 么 可 能 被 用 户 认同 ? 


随 看 计算 机 网 络 应 用 的 不 断 高 速 发 展 ， 随 着 一 大 批 快速 成 长 型 中 
小 企业 的 高 速 发 展 ， 相 信 在 不 久 的 将 来 ， 全 国 将 有 无 数 企 事业 单位 急 
需 高 水 平 、 全 面 掌 握 基 于 计算 机 网 络 基 础 平台 的 IT 设计 和 IT 管理 专业 
人 才 ， 到 那 时 必 将 是 一 场 残酷 的 职业 竞争 。 如 采 连 计算 机 网 络 基础 原 
理 都 没有 比较 好 的 掌握 ， 在 起 跑 线 上 就 输 了 ， 还 如 何 参与 竞争 ? 


基于 以 上 分 析 ， 我 们 可 以 十 分 清楚 地 知道 ， 要 成 为 一 名 合格 的 全 
专业 人 才 ， 无 论 你 是 从 事 IT 应 用 开发 ， 还 是 从 事 网 络 管理 和 网 络 工程 
设计 ， 计 算 机 网 络 基础 原理 都 将 旦 你 的 必修 课 ! 不 要 让 目 己 输 在 起 跑 
Sy 


读者 对 象 


本 书 内 容 看 似 非常 专业 、 深 奥 ， 但 这 方面 的 知识 现在 已 成 为 所 有 
ITer 的 必修 课 。 本 书 适 合 以 下 读者 阅读 ， 每 类 读者 都 可 以 通过 阅读 本 
书 获得 相应 的 收 荔 : 


口 所 有 想 从 事 网 络 管理 、 网 络 工程 设计 的 准 网 络 管理 员 、 准 网 络 
工程 师 


口 所 有 在 网 络 职业 发 展 道路 过 到 基础 理论 瓶 颁 的 在 职 网 络 专业 人 


口 所 有 大 中 专 院 校 的 IT 专业 学 生 


口 所 有 想 学 习 计算 机 网 络 技术 的 “菜鸟 * 


如 何 阅 谈 本 书 


本 书 虽 然 在 知识 讲解 上 已 力争 尽 可 能 通俗 化 ， 但 里 面 的 知识 点 毕 
竞相 当 专 业 ， 所 以 在 阅读 本 书 时 ， 建 议 注意 以 下 儿 个 方面 : 


口 不 要 刻意 追求 阅读 速度 


书 中 有 的 专业 技术 原理 还 是 比较 复杂 的 ， 建 议 大 家 在 阅读 时 要 一 
章 、 一 节 地 消化 ， 不 要 刻意 追求 阅读 速度 。 一 定 要 静 下 心 来 ， 认 真 阅 
读 ， 千 万 别 一 目 十 行 。 


口 结合 书 中 的 示例 阅读 


本 书 所 介绍 的 每 项 技术 原理 都 会 结 
者 一 定 要 仔细 阅读 示例 讲解 的 每 一 步 ， 


算 、 分 析 ， 以 加 深 对 原理 的 理解 。 


合 一 些 关 比 、 演 示 示例 ， 阅 读 
最 好 自己 也 眼 着 示例 进行 计 


尽管 书 中 在 通俗 化 方面 已 有 较 好 的 体现 ， 但 书 中 的 内 容 毕 葛 全 是 
基础 理论 ， 仍 不 能 完全 克服 枯燥 性 ， 远 不 如 图 形 操作 界面 那么 简单 明 
了 ， 所 以 在 阅读 本 书 时 一 定 要 坚持 ， 要 静 下 心 来 学 习 ， 干 万 别 半途 而 
废 。 


口 选 学 内 容 可 先 不 学 


本 书 第 1 章 和 第 9 章 属 选 学 内 容 ， 主 要 是 为 已 有 一 些 基 础 的 读者 而 
准备 的 ， 所 以 如 琳 你 基础 不 是 太 好 ， 可 先 跳 过 这 两 草 ， 等 以 后 有 兴趣 
时 再 来 学 习 。 


本 书 的 特色 


“要 登 泻 入室， 必须 先 打开 一 已 ， 或 者 一 情 窗 ”， 本 书 就 古 你 登 
入 计算 机 网 络 神圣 殿堂 的 那 悄 | 或 窗 。 与 同类 图 书 对 比 ， 本 书 具 有 以 
下 老人 


口 通 丛 易 全 


这 古本 书 最 大 的 特色 。 为 了 能 把 复杂 的 技术 原理 讲 得 通俗 易 懂 ， 
书 中 不 仅 使 用 了 大 量 的 现实 生活 事例 作为 说 明 性 的 比喻 ， 还 列举 了 许 
多 实例 。 同 时 ， 本 书 近 600 幅 插图 、 近 100 个 表格 ， 可 以 帮助 读者 朋友 
更 加 直观 地 分 析 和 理解 各 种 复杂 的 技术 原理 。 这 十 国 内 其 他 同类 图 书 
所 没有 的 。 


口 全 面 系统 


本 书 的 内 容 应 该 是 同类 图 书 中 内 容 最 全 面 、 最 系统 的 ， 不 仅 讲 了 
目前 主流 的 TCP/P 体 系 结构 中 的 相关 技术 ， 还 同时 兼顾 了 OISRM 和 局 
域 网 体系 结构 的 相关 技术 。 更 重要 的 是 还 包括 了 与 各 层 对 应 的 一 些 主 
要 网 络 基础 知识 。 真 正 做 到 “一 本 在 手 ， 网 络 无 忧 ”。 


口 专业 深入 


本 书 对 所 写 到 的 每 一 部 分 内 容 部 从 专业 角度 进行 了 非常 深入 的 副 
析 ， 使 读者 朋友 不 会 有 在 阅读 其 他 同类 图 书 时 所 有 的 许多 重要 知识 后 
都 “一 笔 市 过 ”的 感觉 。 笔 者 在 写作 之 初 承 确立 了 “ 绝 不 一 笔 市 过 那些 重 
要 的 知识 点 ?的 目标 。 


口 条 理 清楚 


本 书 无 论 是 从 各 章 廊 内 容 安 排 上 ， 还 是 从 各 小 市 内 容 组 织 上 ， 条 
理 都 症 比 较 清 楚 的 。 在 本 书 中 ， 对 于 一 些 比 较 复杂 的 内 容 都 分 出 了 多 
个 小 标题 ， 重 点 突出 ， 这 样 可 以 使 读者 朋友 更 加 清楚 地 理解 所 介绍 的 
内 容 ， 不 会 有 整 页 或 者 儿 页 都 找 不 到 主题 、 抓 不 住 重点 的 现象 。 


勘误 和 文 持 


本 书 由 王 达 主笔 并 统 稿 ， 参 加 编写 、 校 验 和 排版 的 人 员 还 有 : 何 
艳 辉 、 王 珂 、 沈 和 之 兰 、 马 平 、 何 江 林 、 刘 凤 竹 、 户 华 、 周 志雄 、 洪 
武 、 高 平复 、 周 建 辉 、 筷 平 、 尚 宝 宏 、 姚 学 军 、 张 右 、 刘 学 、 李 翔 、 
王 娇 、 李 敏 、 吴 鹏 飞 、 宋 布 岭 、 刘 中 洲 、 潘 朝阳 、 刘 伟 、 曾 平 送 、 李 
束 杨 、 张 跃 、 周 平 辉 、 王 新 宇 、 王 薄 、 韩 大 为 、 宋 至 强 、 史 鹏 宇 、 陆 
伟 等 。 笔 者 在 此 对 以 上 各 位 老师 一 并 表示 最 由 囊 的 谢意 ! 尽管 我 们 人 花 
了 大 量 时 间 和 精力 校 验 ， 但 由 于 水 平 有 限 ， 书 中 难免 存在 一 些 错误 和 
瑕 辛 ， 敬 请 各 位 批评 指正 ， 万 分 感谢 ! 


男 外 本 书 读者 可 以 通过 以 下 渠道 至 受 相关 服务 : 


口 多 个 专家 博客 和 认证 微 博 


笔者 的 主要 博客 : http://winda.blog.51cto.com 、 
http://blog.csdn.net/lycb_gz 、 
http:/blog.chinaunix.net/uid/10659021.html。 每 个 博客 里 面 都 有 数 百 篇 
各 方面 的 专业 技术 和 职业 指导 文章 ， 以 及 大 量 我 以 前 所 出 版 的 图 书 的 
精彩 试 读 文章 。 读 者 朋友 不 仅 可 以 在 里 面 学 习 各 方面 的 知识 ， 还 可 以 
直接 向 笔者 提问 。 


笔者 的 两 个 微 博 : weibo.com/winda (新 浪 微 博 ) 、 
t.qq.com/winda2010 (腾讯 微 博 ) 。 


口 超级 QQ 读者 群 


为 方便 全 国 各 地 读者 交流 ， 专 门 为 本 书 读者 新 建 了 一 个 超大 型 、 
可 容纳 2000 人 的 超级 QQ 读者 群 : 196652938。 由 于 读者 众多 ， 请 尽快 
购买 、 加 入 ， 否 则 可 能 很 快 就 没有 位 子 了 (加 入 时 请 注 明 本 书 名 
称 ) 。 


口授 课 PPT 人 免费 下 载 


为 了 支持 高 校 和 培训 机 构 老 师 讲课 ， 本 书 为 各 位 老师 提供 了 授课 
PPT， 需 要 的 朋友 可 以 在 机 械 工 业 出 版 社 华章 公司 官网 
(www.hzbook.com) 上 下 载 ， 也 可 直接 与 笔 联系 获取 (QQ: 
93220994， 邮 箱 : lycb_gz@vip.sina.com) 。 


致谢 


本 书 是 笔者 与 机 械 工业 出 版 社 合作 出 版 的 第 一 部 图 书 ， 感 谢 机 械 
工业 出 版 社 华 草 公司 ， 以 及 杨 福 川 老师 给 予 我 的 这 次 十 分 难得 的 合作 
机 会 。 由 于 本 书 内 容 较 多 ， 专 业 性 较 高 ， 出 版 时 间 又 非常 暴 ， 所 以 特 
别 要 感谢 杨 福 川 老师 专门 为 本 书 抽调 的 精干 编辑 力量 ， 及 他 在 本 书 上 
线 前 做 的 大 量 推 广 工作 ;， 感 谢 让 海 吏 等 其 他 所 有 编辑 老师 对 本 书 的 辛 
勤 付 出 ， 我 经 党 发现 他 们 加 班 加 操 在 编辑 这 部 图 书 。 期 生 本 书 能 取得 
好 的 成 绩 ， 也 期 待 通过 此 部 图 书 合作 的 成 功 ， 为 笔者 与 机 械 工业 出 版 
宪 展 开 更 广泛 的 合作 打下 坚实 基础 。 


第 1 章 ” 数 制 与 编码 


本 章 可 作为 选 学 内 容 ， 所 介绍 的 知识 仅 是 为 了 帮助 大 家 理解 本 书 
以 后 章节 中 涉及 的 二 进 制 、 八 进 制 、 十 六 进 制 的 内 容 ， 每 别 是 各 种 信 
息 编 码 、 卫 地 址 格式 转换 、MAC 地 址 格式 转换 等 内 容 。 本 章 的 知识 对 
于 数据 包 分 析 非 党 有 用 。 如 果 你 对 这 些 内 容 已 掌握 了 ， 可 直接 跳 过 本 


Ne 
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“ 数 制 "是 "数据 进 制 ” 的 简称 ， 也 吕 是 表示 数据 逢 几 进 位 的 意思 ， 
如 我 们 常用 的 十 进 制 就 是 着 十 进位 。 当 然 ， 数 制 的 类 型 远 不 只 十 进 
制 ， 在 计算 机 系统 中 常见 的 还 有 二 进 制 、 八 进 制 和 十 六 进 制 这 三 种 。 
与 数 制 关 系 最 密切 当然 惑 是 数据 编码 了 “。 数 据 编码 主要 包括 原 码 、 反 
码 和 补 码 三 种 ， 它 们 用 于 以 不 同形 式 表示 数据 ， 当 然 这 主要 是 一 些 特 
殊 的 应 用 需求 ， 如 在 进行 校 验 和 (checksum) 计算 时 ， 就 需要 用 于 原 
码 计算 。 反 码 和 补 码 是 为 了 在 计算 机 中 表示 人 负数 才 出 现 的 。 本 章 的 主 
要 内 容 就 古 数 制 与 编码 的 概念 ， 以 及 二 进 制 的 运算 和 表示 形式 。 


1.1 数 制 概述 


“ 数 制 ? 束 是 "数据 进 制 "的 简称 ， 有 是 指数 据 的 进位 计数 规则 ， 又 
称 “ 进 位 计数 制 "， 简 称 “ 进 制 ”。 本 世 移 来 简单 地 了 解 一 些 芝 见 的 数 制 


类 型 及 其 特点 。 


1.1.1 和 常见 数 制 类 型 及 表示 方法 


日 常生 活 中 我 们 经 芝 使 用 的 数 是 十 进 制 的 ， 如 我 们 拿 的 3000 元 工 
次 ， 市 场 1.5 元 / 斤 的 菜 价 等 。 之 所 以 称 其 为 十 进 制 ， 是 因为 这 类 数 十 着 
十 进 一 的 。 除 了 十 进 制 计数 以 外 ， 还 有 许多 其 他 进 制 的 计数 方法 。 在 
计算 机 中 管见 的 还 有 二 进 制 、 八 进 制 、 十 六 进 制 等 制式 。 这 三 种 进 制 
的 数 在 进行 加 法 运算 中 分 别 是 逢 二 、 八 、 十 六 进 一 ， 这 就 是 前 面 所 说 
的 进位 计数 规则 。 关 于 如 何 理解 这 些 不 同 数 制 类 型 数据 的 加 法 运算 ， 
在 本 章 后 面 将 有 专门 介绍 。 


其 实数 制 类 型 远 不 止 这 么 几 种 ， 如 我 们 以 60 分 钟 为 1 小 时 ，60 秘 为 
一 分 钟 ， 用 的 殉 是 六 十 进 制 计 数 法 ;一 天 之 中 有 24 小 时 ， 用 的 是 二 十 
四 进 制 计数 法 ;而 一 星期 有 7 天 ， 用 的 是 七 进 制 计数 法 。 


虽然 数 制 类 型 可 以 有 很 多 种 ， 但 在 计算 机 通信 中 通常 遇 到 的 仍 是 
以 上 提 到 的 二 进 制 、 八 进 制 、 十 进 制 和 十 六 进 制 这 四 种 。 在 一 种 数 制 
中 所 能 使 用 的 数码 的 个 数 称 为 该 数 制 的 “基数 ”"， 也 整 是 对 应 数 制 类 型 
的 名 称 ， 如 二 进 制 的 基数 为 “2”， 八 进 制 的 基数 为 "8"， 十 进 制 的 基数 
为 “10”， 十 六 进 制 的 基数 也 就 是 <16”。 这 里 所 说 的 “基数 ”其 实 就 是 前 
面 所 说 的 进位 计算 规则 ， 如 我 们 常见 的 十 进 制 数 古道 十 进 一 ， 二 进 制 


a 


既然 有 不 同 的 数 制 ， 那 么 在 计算 机 程序 中 给 出 一 个 数 时 就 必须 指 
明 它 属于 哪 一 种 数 制 ， 否 则 计算 机 程序 束 不 知道 该 把 它 看 成 哪 种 数 
了 。 如 12300 这 个 数 ， 既 可 能 是 十 进 制 、 又 可 能 是 八进制 或 者 十 六 进 
制 ， 所 以 “ 数 ” 需 要 有 专门 的 标志 来 进行 区 别 。 下 面 分 别 予 以 介绍 。 


(1) 十 进 制 (Decimal) 


F 进 制 是 日 常生 活 中 常用 的 数 制 类 型 ， 基 数 是 10， 也 就 是 它 有 10 
个 数字 符号 ， 即 0、1、2、3、4、5、6、7、8、9。 其 中 最 大 数码 是 “ 基 
数 ” 减 1， 即 10-1=9， 最 小 数码 是 0°。 十进制 数 的 标志 为 D， 如 (1250) 
D， 也 可 用 下 标 *10” 来 表示 ， 如 〈1250) 10 (注意 是 下 标 ) 。 


(2) 二 进 制 (Binary) 


二 进 制 是 计算 机 运算 时 所 采用 的 数 制 ， 基 数 是 2， 也 就 是 说 它 只 有 
两 个 数字 符号 ， 即 0 和 1。 如 果 在 给 定 的 数 中 ， 除 0 和 1 外 还 有 其 他 数 
(例如 1061) ， 那 它 就 绝 不 会 是 一 个 二 进 制 数 了 。 二 进 制 数 的 最 大 数 
码 也 是 基数 减 1， 即 2-1=1， 最 小 数码 也 是 0。 二 进 制 数 的 标志 为 B， 如 
(1001010) B， 也 可 用 下 标 “2?” 来 表示 ， 如 〈1001010) ， (注意 是 下 


标 ) 。 


(3) 八进制 (Octal) 


八进制 的 基数 是 8， 也 就 是 说 它 有 8 个 数字 符号 ， 即 0、1、2、3、 
4、5、6、7。 对 比 十 进 制 可 以 看 出 ， 它 比 十 进 制 少 了 两 个 
数 “8” 和 “9”， 这 样 当 一 个 数 中 出 现 “8” 和 (或 )“9” 时 (如 23459) ， 那 
它 也 就 绝 不 是 八进制 数 了 。 八 进 制 数 的 最 大 数码 也 是 基数 减 1， 即 8- 
1=7， 最 小 数码 也 是 0。 八 进 制 数 的 标志 为 0 或 Q (注意 它 特别 一 些 ， 可 
以 有 两 种 标志 ) ， 如 (4603) O (注意 是 字母 0O， 不 是 数字 0) 、 
(4603) Q， 也 可 用 下 标 “8” 来 表示 ， 如 (4603) 8 (注意 是 下 标 ) 。 
在 C、C++ 这 类 语言 中 规定 ， 一 个 数 如 果 要 指明 它 采 用 八进制 ， 必 须 在 
它 前 面 加 上 一 个 0， 如 : 123 是 十 进 制 数 ， 但 0123 则 表示 采用 的 是 八 进 
制 。 


(4) 十 六 进 制 〈(Hexadecilmal) 


十 六 进 制 数 用 得 比较 少 ， 最 新 的 IPv6 地 址 就 是 采用 16 进 制 来 表示 
的 〈IPv4 地 址 通常 采用 十 进 制 表示 ) 。 在 注册 表 中 也 会 用 到 16 进 制 ， 
所 以 了 解 十 六 进 制 还 是 非常 重要 的 。 


上 六 进 制 的 基数 是 16， 也 就 是 说 它 有 16 个 数字 符号 ， 除 了 十 进 制 
中 的 10 个 数 外 ， 还 使 用 了 6 个 英文 字母 ， 这 16 个 数字 和 字母 依次 是 0、 
1、2、3、4、5、6、7、8、9、A、B、C、D、E、F (与 大 小 写 无 
关 ) 。 其 中 A 至 F 分 别 代 表 十 进 制 数 的 10 至 15。 如 果 数 据 中 出 现 了 字母 
之 类 的 符号 ， 如 63AB， 则 一 定 不 会 是 八进制 或 十 进 制 ， 而 是 十 六 进 制 
了 。 它 的 最 大 的 数码 也 是 “基数 ” 减 1， 即 16-1=15 (为 F) ， 最 小 数码 也 


是 0°。 十 六 进 制 数 的 标志 为 H， 如 (4603) 再 ， 也 可 用 下 标 *16” 来 表 
示 ， 如 (4603) 16 (注意 是 下 标 ) 。 十 六 进 制 数 也 常常 用 前 级 0x 来 表 
示 (注意 是 数字 0， 而 不 是 字母 0O) 。 在 C、C++ 这 类 编程 语言 中 也 规 
定 ，16 进 制 数 必须 以 0x 开 头 。 比 如 0x10 表 示 一 个 十 六 进 制 数 ， 而 不 是 
八进制 或 者 十 进 制 的 10。 


经 验 之 谈 ”既然 在 计算 机 中 使 用 的 是 二 进 制 ， 那 为 什么 还 要 十 进 
制 、 八 进 制 和 十 六 进 制 呢 ? 其 实 这 都 不 是 计算 机 自 喘 要 求 的 ， 因 为 在 
计算 机 运算 中 使 用 的 全 都 是 二 进 制 。 之 所 以 还 需要 这 些 数 制 ， 完 全 出 
于 表达 和 识别 的 方便 性 考虑 。 因 为 大 多 数 的 数据 用 二 进 制 表示 太 长 
了 ， 如 一 个 C、C++ 等 编程 语言 中 的 int (整数 ) 类 型 的 数据 要 占用 4 个 
字 节 ， 也 就 是 32 位 。 比 如 100， 用 int 类 型 的 二 进 制 数 表达 将 是 : 0000 
0000 0000 0000 0110 0100。 这 还 是 一 个 比较 小 的 数 ， 如 采 数 更 大 ， 则 
会 更 复杂 。 试 想 一 下 ， 要 写 这 么 长 ， 估 计 没 几 个 人 会 喜欢 ， 于 是 就 有 
了 可 以 更 简便 表示 的 十 进 制 、 八 进 制 和 十 六 进 制 了 。 所 以 ， 像 C、 
C++ 这 类 语言 没有 提供 在 代码 中 直接 写 二 进 制 数 的 方法 ， 而 是 普遍 采 
用 八进制 或 十 六 进 制 。 


那 为 什么 不 是 其 他 进 制 类 型 ， 如 九 或 二 十 进 制 呢 ? 原因 就 在 于 2、 
8、16， 分 别 是 2 的 1 次 方 、3 次 方 、4 次 方 ， 这 就 使 得 这 三 种 进 制 之 间 可 
以 非常 直接 地 互相 转换 。 八 进 制 或 十 六 进 制 缩短 了 二 进 制 数 ， 但 保持 


了 二 进 制 数 的 表达 特点 。 在 下 面 天 于 进 制 转换 的 介绍 中 ， 你 可 以 发 现 
人 


1.1.2 ”不 同 数 制 之 间 的 对 应 关系 


表 1-1 所 示 是 以 上 介绍 的 二 进 制 、 十 进 制 、 八 进 制 和 十 六 进 制 这 四 
种 常 在 计算 机 中 使 用 的 数 制 的 对 应 关系 。 注 意 ， 八 进 制 没 有 8 和 9， 二 
进 制 1000 对 应 八进制 的 10， 而 不 是 想象 中 的 8， 二 进 制 1001 对 应 的 八 进 
制 数 是 11， 而 不 是 想象 中 的 9， 这 就 是 进位 造成 的 。 这 个 表 很 重要 ， 大 
家 最 好 全 部 记 下 来 ， 等 别 是 这 几 种 数 制 的 对 应 关系 。 


表 1-1 不 同 数 制 的 对 应 关系 
二 进 制 数 对 应 的 十 进 制 数 对 应 的 八进制 数 对 应 的 十 六 进 制 数 
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1.2 不 同 数 制 则 的 相互 转换 


同一 个 数 在 一 些 环 境 中 (如 我 们 要 进行 子 网 划分 ， 或 者 计算 子 网 
掩 码 时 ， 或 者 对 信息 进行 编码 时 等 可 能 要 用 不 同 数据 制 形 式 来 表 
示 ， 这 束 涉 及 数 制 间 的 转换 问题 了 。 下 面 古 常见 的 十 进 制 、 二 进 制 、 
八进制 、 十 六 进 制 之 间 的 转换 方法 。 


1.2.1 非 十 进 制 数 转 换 成 十 进 制 数 


非 十 进 制 数 转换 成 十 进 制 数 束 是 把 这 些 非 十 进 制 数 按 位 以 对 应 的 
权 值 (注意; 要 区 分 整数 位 和 小 数位 ) 展开 ， 然 后 相 加 即 得 出 相应 的 
十 进 制 值 。 本 市 后 面 介绍 的 各 种 非 十 进 制 转 换 成 十 进 制 的 方法 都 是 按 
照 这 种 方法 进行 的 。 


“ 权 值 ” 钙 指 对 应 数值 位 的 进 制 贤 次 方 数 ， 如 二 进 制 整 数 中 第 0 位 
(最 低位 ， 也 就 是 整数 最 右边 的 那 位 的 权 值 是 2 的 0 次 方 ， 第 1 位 的 权 
值 是 2 的 1 次 方 ..…. 同 理 在 八进制 整数 中 第 0 位 的 权 值 是 8 的 0 次 方 ， 第 1 
位 的 权 值 是 8 的 1 次 方 ……， 依 此 类 推 。 但 每 位 的 权 值 会 因 是 整数 位 还 
征 小 效 位 而 不 同 : 


口 整数 的 第 0 位 〈 也 就 是 最 低位 ) 的 权 值 为 对 应 进 制 的 0 次 方 ， 最 
高 位 的 权 值 为 对 应 进 制 的 n-1 次 方 。 


口 小 数 的 第 一 位 〈 最 靠近 小 数 点 的 那 位 ， 也 是 小 数 的 最 高 位 ) 的 
权 值 为 对 应 进 制 的 -1 次 方 ， 最 后 一 位 (最 右边 的 那 位 ， 也 即 小 数 的 最 
低位 ) 的 权 值 为 对 应 进 制 的 -n 次 方 。 


1. 二 进 制 转换 为 十 进 制 


二 进 制 转换 成 十 进 制 的 方法 ， 大 家 可 能 早 束 有 所 了 解 了 ， 如 在 
IPv4 地 址 计算 时 吏 经 党 进行 这 样 的 操作 。 转 换 的 方法 比较 简单 ， 只 需 
按 它 的 权 值 展开 即 可 。 展 开 的 方式 是 把 二 进 制 数 首 先 写成 加 权 系 数 展 
格式 ， 然 后 按 十 进 制 加 法 规则 求 和 。 这 种 方法 称 为 “ 按 权 相 加 ”法 。 


二 进 制 整数 部 分 的 一 般 表 现形 式 为 : bl .bl bo ( 共 n 位 ) ， 按 权 
相 加 展开 后 的 格式 为 注意， 展开 式 中 从 左 往 右 各 项 的 需 次 是 从 高 到 
低下 降 的 ， 最 高 位 的 需 为 n-1， 节 低 的 需 为 0) : 


By KOT TA Xb 2 2 
如 二 进 制 数 (11010) ,的 按 权 相 加 展开 格式 为 : 
1x24 +1x23 +0x22 +1x21 +0x20 =16+8+0+2+0=(26)10 


二 进 制 小 数 部 分 的 需 次 是 反 序 排列 的 〈 也 就 是 与 整数 部 分 的 需 次 
序列 相反 ， 从 左 往 右 其 绝对 值 是 从 低 到 高 上 升 的 ) ， 且 为 负 值 ， 最 高 
位 大 次 《也 吕 是 最 靠近 小 数 点 的 第 一 个 小 数位 的 需 次 ) 为 “-1”。 如 二 


进 制 小 数 部 分 的 格式 为 ，0.b,.1 .…bi by ， 则 按 权 相 加 后 的 展开 格式 


2 

如 《0.1011) ， 的 按 权 相 加 展开 格式 为 : 

1x2-1 +0x2™* +1x2-3 +1x24 =0.5+0+0.125+0.0625=(0.6875)10 
2. 八 进 制 转换 为 十 进 制 


八进制 转换 成 十 进 制 也 是 采取 “ 按 权 相 加 ”法 ， 只 是 这 里 的 权 值 是 8 
的 相应 需 次 方 。 如 八进制 整数 部 分 的 格式 为 : bl .…b1 bo ， 则 按 权 值 
相 加 ， 展 开 后 的 格式 就 为 《从 左 往 右 需 次 是 从 高 到 低下 降 的 ) : 


b，; x8n1 +b，， x8n“ ...+bi x81 +bo x80 
如 八进制 数 (26356)g 的 按 权 值 相 加 展开 格式 为 : 


2x84 +6x83 +3x8“ +5x81 +6x80 =8192+3072+192+40+6=(11502)10 


八进制 小 数 部 分 的 索 次 也 是 反 序 排列 的 (也 就 是 与 整数 部 分 的 过 
次 序列 相反 ， 从 左 往 右 其 绝对 值 是 从 低 到 高 上 升 的 ， 且 为 负 值 ， 最 
低 震 次 (也 就 是 最 靠近 小 数 点 的 第 一 个 小 数位 的 震 次 ) 为 <1”。 如 八 
进 制 小 数 部 分 的 格式 为 : 0b ，..b by ， 则 按 权 相 加 后 的 展开 格式 
为 


b 1 x8-1 +b ，x8-2 ...+bi x8- WY +bo x8™ 
如 “(0.257) 8 按 权 相 加 的 展开 格式 为 : 


2x8-1 +5x8-2 +7x8-3 =0.25+0.078125+0.013671875=(0.341796875)10 


3. 十 六 进 制 转换 为 十 进 制 


十 六 进 制 转换 成 十 进 制 的 方法 也 是 采取 “ 按 权 相 加 ”法 ， 只 是 这 里 
的 权 值 是 16 的 相应 内 次 方 。 如 十 六 进 制 整数 部 分 的 格式 为 : bi.1 bn .… 
bi bo ， 则 按 权 相 加 展开 后 的 格式 就 为 〈 从 左 往 右 需 次 是 从 高 到 低下 降 
的 ) : 


b， 1 16"1 +b，> x16n ...+b; x161 +bo x160 
如 十 六 进 制 数 (26345)16 的 按 权 相 加 ， 展 开 后 的 格式 为 : 


2x164 +6x163 +3x162 +4x161 +5x160 =131072+24576+768+64+5= 
(156485) 10 


十 六 进 制 小 数 部 分 的 需 次 也 是 反 序 排列 的 〈 也 就 是 与 整数 部 分 的 
寡 次 序列 相反 ， 从 左 往 右 其 绝对 值 是 从 低 到 高 上 升 的 )， 且 为 负 值 ， 
最 低 需 次 〈 也 就 是 最 靠近 小 数 点 的 第 一 个 小 数位 的 需 次 ) 为 “-1”。 如 
十 六 进 制 小 数 部 分 的 格式 为 : 0.bui …bli bo ， 则 按 权 相 加 后 的 展开 格式 
为 : 


b,1 x16-1 +b，， x16-2 ...+b] x16- Anal) +bo x16™ 
如 《0.25A) 16 按 权 值 相 加 ， 展 开 后 的 格式 为 : 


2x16-1 +5x16- +10x16-3 =0.125+0.0234375+0.00244140625= 
(0.15087890625) 10 


4. 同 步 练 习 
1) 把 (01110100) B、 (11101001000.10111) B 转 换 成 十 进 制 ; 
2) 把 (1076) O、 (6374.65) Q 转 换 成 十 进 制 ; 


3) 把 0x7A8C、0x259B.25 转 换 成 十 进 制 。 


1.2.2 十进制 数 转换 成 非 十 进 制 数 


十 进 制 数 转换 成 非 十 进 制 数 的 方法 是 ， 整数 部 分 的 转换 用 “ 除 基 取 
余 法 ”， 也 就 是 用 基数 相 除 ， 然 后 反 序 (由 后 向 前 取 ) 取 余 数 ， 小 数 部 
分 的 转换 用 “ 乘 基 取 整 法 ">， 也 就 是 用 基数 相 乘 ， 然 后 正 序 (由 前 向 后 
取 ) 取 整 数 。 这 里 的 “基数 "就 是 对 应 的 数 制 ， 如 二 进 制 的 基数 为 2， 八 
进 制 的 基数 为 89， 十 六 进 制 的 基数 为 16。 


1. 十 进 制 转换 为 二 进 制 


这 里 分 别 对 十 进 制 整数 和 十 进 制 小 数 转 换 成 二 进 制 进行 介绍 。 


1) 十 进 制 整 数 转 换 成 二 进 制 的 方法 


十 进 制 整 数 转 换 为 二 进 制 的 方法 是 ， 采 用“ 除 2 逆序 取 余 ”法 (采用 
短 除 法 进行 ) 。 也 就 是 先 将 十 进 制 数 除 以 2， 得 到 一 个 商 数 (也 是 下 一 
步 的 被 除数 ) 和 余数 ;然后 再 将 商 数 除 以 2， 又 得 到 一 个 商 数 和 余数 ; 
以 此 类 推 , 直 到 丙 数 为 小 于 2 的 数 为 止 。 然 后 从 最 后 一 步 得 到 的 小 于 2 
的 商 数 开始 将 其 他 各 步 所 得 的 余数 〈 也 都 是 小 于 2 的 0 或 1) 排列 起 来 

(俗称 “逆序 排列 ”) 就 得 到 了 对 应 的 二 进 制 数 。 


注意 ”这 里 与 下 面 的 小 数 转换 有 些 不 一 样 ， 这 里 要 包括 最 后 得 到 
的 小 于 2 的 商 数 ， 而 小 数 转换 中 是 不 需要 包括 最 后 的 积 的 ， 只 包括 各 步 


得 到 的 整数 部 分 ， 后面 的 十 进 制 整数 转换 为 八进制 、 十 六 进 制 也 一 
样 。 


图 1-1 所 示 为 十 进 制 整数 48 转 换 成 二 进 制 数 时 依次 除 2 的 过 程 ， 在 每 
步 的 最 右边 显示 的 是 各 步 商 数 除 2 所 得 到 的 余数 ， 最 后 一 步 的 商 数 为 
1， 因 为 它 小 于 2， 所 以 不 能 再 除了 。 然 后 从 最 后 得 到 商 数 (1) 开始 依 
次 向 上 把 其 他 各 步 除 2 得 到 的 余数 排列 起 来 ， 就 得 到 最 后 48 转 换 成 二 进 
制 时 的 结果 为 (110000)。。 同 理 ， 图 1-2 所 示 的 十 进 制 数 250 转 换 成 二 进 
制 数 后 的 结 采 就 为 (11111010)。。 


余数 
2|48 0 
2|24 0 
2L2 0 
2L6_ 0 
213 


] 


图 1-1 十 进 制 整数 48 转 换 成 二 进 制 整数 的 步骤 


2|250 0 
25 
2|62 0 
2|31 1 
2[15 1 
入 | 芝 。 
2|3_ 1 
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图 1-2 十 进 制 整数 250 转 换 成 二 进 制 整数 的 步骤 
2) 十 进 制 小 数 转 换 成 二 进 制 的 方法 


十 进 制 小 数 转换 为 二 进 制 的 方法 是 采用 “ 乘 2 正 序 取 整 "法 。 也 束 是 
用 2 乘 十 进 制 小 数 ， 得 到 一 个 积 ， 然 后 将 积 的 整数 部 分 取出 作为 相应 步 
又 得 到 的 整数 ， 再 用 2 乘 余 下 的 小 数 部 分 ， 叉 得 到 一 个 积 ， 然 后 再 将 这 
个 积 的 整数 部 分 取出 ， 以 此 类 推 ， 直 到 积 中 的 小 数 部 分 为 者， 或 者 达 
到 所 要 求 的 精度 为 止 ， 最 后 把 各 步 取出 的 整数 部 分 〈 仅 需要 各 步 得 到 
的 整数 部 分 ， 不 需要 最 后 没有 取 整 的 小 数 部 分 按 正 序 排列 起 来 ， 即 
先 取 的 整数 作为 二 进 制 小 数 的 高 位 ， 后 取 的 整数 作为 低位 。 


图 1-3 的 左 、 上 图 是 分 别 将 十 进 制 小 数 0.125 和 0.625 转 换 成 二 进 制 的 
过 程 ， 最 后 得 到 的 二 进 制 数 就 是 从 最 开始 得 到 的 整数 值 开始 ， 一 直到 
最 后 得 到 的 整数 值 (也 就 是 自 上 而 下 的 顺序 ， 与 整数 转换 中 取 余 的 顺 
序 相反 ) 。0.125 和 0.625 最 后 的 二 进 制 值 分 别 为 (0.001) 。 和 (0.101) 
， (注意 ， 一 定 要 记得 在 整数 部 分 加 上 “0.”， 因 为 十 进 制 小 数 转换 成 二 
进 制 后 仍 是 小 数 ) 。 


0.125 ”得 到 的 整数 0.625 得 到 的 整数 
* 2 0 * 2 ] 
0.25 1.250 
去 掉 整 数 
x py 3 一 > 0.250 
0 ”部 分 的 值 0 
0.50 x 2 
x 2 
一 一 一 ] 
1.00 
0.00 1.000 


0.000 


图 1-3 0.125 和 0.625 十 进 制 小 数 转 换 成 二 进 制 小 数 的 步骤 


注意 ”有 些 十 进 制 小 数 乘 以 2 后 是 个 无 穷 循环 数 ， 永 远 不 会 有 完整 
的 整数 ， 此 时 就 要 看 所 需 的 精度 如 何 了 ， 按 所 需 位 数 精度 取 值 即 可 。 
如 0.825 束 是 这 样 一 个 数 ， 如 果 仅 要 求 是 小 数 点 后 3 位 ， 则 相应 的 二 进 制 


数 为 〈0.110) ，， 如 果 要 求 为 4 位 ， 则 对 应 的 二 进 制 值 为 〈0.1101) ，。 
具体 如 图 1-4 所 示 。 


0.825 ”得 到 的 整数 
X 2 
0.650 
x fy 
0.300 
X 2 
0.600 
关 2 
0.200 


] 


图 1-4 不 同 精确 度 要 求 的 取 值 示例 


如 琳 一 个 十 进 制 同 时 有 整数 和 小 数 部 分 ， 则 要 对 整数 和 小 数 部 分 
分 别 按 以 上 介绍 的 对 应 方法 进行 二 进 制 转 换 。 


2. 十 进 制 转换 成 八进制 


八进制 数 的 基数 为 8， 因 此 八进制 数 中 的 数码 有 0、1、2、3、4、 
5、6、7， 共 八 个 。 十 进 制 转换 成 八进制 的 方法 与 前 面 介 绍 的 十 进 制 数 
转换 成 二 进 制 的 方法 类 似 ， 只 不 过 这 里 的 基数 是 8 (而 不 再 是 2) 。 十 


进 制 转换 成 八进制 当然 也 分 整数 部 分 和 小 数 部 分 两 种 不 同 的 转换 方 
2 


十 进 制 整 数 转 换 为 八进制 整数 采用 “ 除 8 逆 序 取 余 ” 的 方法 ， 直 到 所 
得 的 商 小 于 8， 然 后 把 余数 (包括 最 后 一 步 中 得 到 的 小 于 8 的 商 数 ) 按 
送 序 排列 即 可 ;， 十进制 小 数 转换 为 八进制 小 数 是 采用 “ 乘 8 正 序 取 
整 ” 法 ， 直 到 所 得 到 的 积 小 数 部 分 为 0， 或 者 在 规定 的 精度 范围 内 ， 然 
后 把 所 得 到 的 整数 正 序 排列 起 来 即 可 。 


图 1-5 左 、 上 图 是 分 别 将 十 进 制 整数 65 和 2467 按 “ 除 8 逆序 取 余 ”的 方 
法 转换 成 八进制 的 步骤 ， 得 到 的 结果 分 别 是 (101) 8 和 (4643) 8 。 


余数 
余 兰 
Re 8|2467 3 
8|165 1 
8|308 4 
8 18 
[8 0 sa8 6 
| 4 


图 1-5 两 个 十 进 制 整数 转换 成 八进制 整数 的 步 双 


图 1-6 左 、 上 图 所 示 的 是 两 个 十 进 制 小 数 0.125 和 0.8125 通 过 “ 乘 8 正 
序 取 整 * 的 方法 转换 成 八进制 的 步骤 ， 得 到 的 结果 分 别 是 (0.1) 。 和 


(0.64) 8 ( 古 正 序 排列 ， 一 定 要 记得 在 整数 部 分 加 上 “0.”) 。 


0.125 ”得 到 的 整数 0.8125 ”得 到 的 整数 
X 8 ] X 8 6 
1.000 6.5000 
0.000 0.5000 
x 8 4 
4.0000 
0.0000 


图 1-6 两 个 十 进 制 小 效 转换 成 八进制 小 数 的 步 又 


3. 十 进 制 转换 成 十 六 进 制 


十 六 进 制 数 的 基数 为 6， 十 六 进 制 数 中 的 数码 有 0、1、2、3、4、 
5、6、7、8、9、A、B 、C、D、E、E， 共 十 六 个 。 


十 进 制 转换 成 十 六 进 制 与 十 进 制 转 换 成 二 进 制 类 似 ， 将 十 进 制 整 
数 转 换 为 十 六 进 制 的 方法 是 采用 “ 除 16 逆 序 取 余 ” 法 ， 直 到 所 得 的 商 小 
于 16， 然 后 把 余数 (包括 最 后 一 步 中 得 到 的 小 于 16 的 商 数 ) 按 送 序 排 
列 即 可 ; 十进制 小 数 转 换 为 十 六 进 制 的 方法 是 采用 "“ 乘 16 正 序 取 
整 ” 法 ， 直 到 所 得 到 的 积 小 数 部 分 为 0， 或 者 在 规定 的 精度 范围 内 ， 然 
后 把 所 得 到 的 整数 正 序 排列 起 来 即 可 。 


图 1-7 左 、 上 图 是 分 别 将 十 进 制 整数 45 和 3456 按 “ 除 16 逆 序 取 余 ”的 
方法 转换 成 十 六 进 制 的 步 又 ， 得 到 的 结果 分 别 是 (2D)je 和 (D80)1。 ( 注 
意 ， 其 中 的 13 用 十 六 进 制 的 DD 表示 了 ) 。 


余数 余数 
16|45 13 16|3456 0 
2 16 |216 8 

13 


图 1-7 两 个 十 进 制 整数 转换 成 十 六 进 制 整数 的 步 又 


图 1-8 左 、 上 图 是 将 十 进 制 小 数 0.125 和 0.825 通 过 “ 乘 16 正 序 取 整 ” 的 
方法 转换 成 十 六 进 制 的 步骤 ， 得 到 的 结果 分 别 是 (0.2) 16 和 (0.D33) 
16 《精确 到 小 数 点 后 面 三 位 ) (注意 : 是 正 序 排列 ， 也 一 定 要 记得 在 
整数 部 分 加 上 “0.”， 仍 是 小 数 ) 。 


0.125 ”得 到 的 整数 0.823 ”得 到 的 整数 
x 16 ) 1 16 13 
2.000 0.2 
0.000 x 16 3 
0.2 
x 16 3 


0.2 


图 1-8 两 个 十 进 制 小 数 转换 成 十 六 进 制 小 数 的 步 又 


4. 同 步 练习 


1) 把 十 进 制 数 825、10815.6 转 换 成 二 进 制 ; 


2) 把 十 进 制 数 658、9240.65 转 换 成 八进制 ; 


3) 把 十 进 制 数 2508、5420.82 转 换 成 十 六 进 制 。 


1.2.3” 非 十 进 制 数 之 间 的 相互 转换 


从 表 1-1 可 以 得 出 这 样 一 个 规律 : 1 位 八进制 数 对 应 3 位 二 进 制 数 ， 
而 1 位 十 六 进 制 数 对 应 4 位 二 进 制 数 。 因 此 ， 二 进 制 数 与 八进制 数 之 
间 、 二 进 制 数 与 十 六 进 制 数 之 间 的 相互 转换 十 分 容易 。 


1. 相 互 转换 方法 
非 十 进 制 数 间 的 具体 转换 方法 如 下 : 


1) 八进制 数 转换 成 二 进 制 数 的 方法 是 : 将 每 1 位 八进制 数 直 接 用 
相应 的 3 位 二 进 制 来 表示 ; 二 进 制 数 转换 成 八进制 数 的 方法 是 : 以 小 数 
点 为 边界 ， 整 数 部 分 向 左 ， 小 数 部 分 向 右 将 每 3 位 二 进 制 分 成 一 组 ， 硅 
不 足 3 位 则 用 0 补足 3 位 ， 然 后 将 每 一 组 二 进 制 数 直接 用 相应 的 1 位 八 进 
制 来 表示 。 


例如 要 将 (3456.2262)8 转换 为 二 进 制 数 的 方法 是 依次 把 八进制 的 
每 1 位 用 3 位 二 进 制 表 示 (如 图 1-9 所 示 ) ， 最 后 的 结果 为 
(11100101110.010010101010)。 (整数 部 分 最 前 面 的 0 可 以 省 略 ) 。 


34506.2202 


有 由 内 六 六 六 


011 100 101 110:010 010 101 010 
1-9 八进制 转换 成 二 进 制 示 例 


例如 要 将 (1101011.10111) ,转化 为 八进制 数 ， 可 以 把 整数 部 分 
从 右 向 左 每 3 位 分 为 一 组 ， 最 后 不 足 3 位 时 加 0 补 上 ， 然 后 把 小 数 部 分 从 
左 向 右 (与 整数 部 分 的 划分 顺序 相反 ) 同样 以 每 3 位 分 为 一 组 ， 最 后 不 
足 3 位 时 加 0 补 上 (如 图 1-10 所 示 ) ， 最 后 的 结果 为 (153.56) 8。 


补 加 的 0 
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图 1-10 二 进 制 转换 成 八进制 示例 


2) 十 六 进 制 数 转换 成 二 进 制 数 的 方法 是 ， 将 每 1 位 十 六 进 制 数 直 
接 用 相应 的 4 位 二 进 制 来 表示 。 二 进 制 数 转换 成 十 六 进 制 数 的 方法 是 : 
以 小 数 点 为 边界 ， 整 数 部 分 同 左 ， 小 数 部 分 同 右 将 每 4 位 二 进 制 数 分 成 


一 组 ， 若 不 足 4 位 则 用 0 补足 4 位 ， 然 后 将 每 一 组 二 进 制 数 直接 用 相应 的 
1 位 十 六 进 制 表示 。 


例如 将 (4AF.51)16 转换 成 二 进 制 数 的 最 后 结果 为 (100 1010 
1111.0101 0001), ; 将 二 进 制 数 (11 0110 1110.1010 1010 1000)。 (最 后 
部 分 的 三 个 0 是 划分 位 时 补 上 去 的 ， 下 同 ) 转换 为 十 六 进 制 数 的 最 后 结 
果 为 (36E.AA8)j6。 


3) 八进制 与 十 六 进 制 的 相互 转换 最 好 的 方法 就 是 先 把 其 中 一 个 转 
换 成 二 进 制 ， 然 后 再 把 所 得 到 的 二 进 制 转换 成 男 一 个 进 制 的 数 。 


如 八进制 数 (6237.431)8 转换 成 十 六 进 制 的 步骤 为 : 


步骤 1: 将 (6237.431)8 转换 成 二 进 制 (每 1 位 用 3 位 二 进 制 表 
示 ) ， 得 到 的 二 进 制 结果 是 (110010011111.100011001)，。 


步骤 2: 再 将 (1100 1001 1111.1000 1100 1000) , 转换 成 十 六 进 制 
(以 小 数 点 为 边界 ， 整 数 部 分 从 右 向 左 每 4 位 分 为 一 组 ， 最 后 不 足 4 位 
时 加 0 补 上 ， 然 后 把 小 数 部 分 从 左 向 右 将 每 4 位 二 进 制 数 分 成 一 组 ， 若 
不 足 4 位 则 用 0 补足 4 位 ) ， 得 到 最 终 的 十 六 进 制 结果 为 (C9F.8C8)16。 


将 十 六 进 制 3AB.11)16 转换 成 八进制 的 步骤 与 上 边 的 步骤 类 似 ， 
具体 转换 过 程 如 下 : 


步骤 1 先 将 十 六 进 制 数 (3AB.11)16 转换 成 二 进 制 ， 得 到 
(001110101011.00010001)。。 


步骤 2， 再 将 (001 110 101 011.000 100 010), 转换 成 八进制 以 小 数 
点 为 边界 ， 整 数 部 分 从 右 向 无 每 3 位 分 为 一 组 ， 最 后 不 足 3 位 时 加 0 补 
上 ， 然 后 把 小 数 部 分 从 左 向 右 将 每 3 位 二 进 制 数 分 成 一 组 ， 若 不 足 3 位 
则 用 0 补足 3 位 ， 最 后 的 结果 为 (1653.042)8。 


以 上 二 进 制 、 八 进 制 、 十 六 进 制 的 对 应 关系 可 参见 表 1-1， 根 据 该 
表 可 直接 进行 转换 。 


2. 同 步 练 习 


1) 把 (1011011)B、(10110111.0010)B 转 换 成 八进制 ; 


2) 把 (1100111011)B、(11101001.101)B 转 换 成 十 六 进 制 ; 
3) 把 (758)O、(8265.42)O 转 换 成 十 六 进 制 ; 


4) 把 0xA58C、0x8152.78 转 换 成 八进制 。 


1.3 ”二进制 效 运算 


二 进 制 数 在 计算 机 中 是 应 用 最 广 的 ， 因 为 它 最 简单 ， 数 码 仅 1 和 0 
两 个 ， 可 以 代表 电 平 的 高 和 低 ， 或 者 电压 的 正和 负 ， 或 者 电路 的 开 与 
关 等 。 


对 于 二 进 制 数 ， 除 了 与 十 进 制 数 一 样 可 以 进行 四 则 算术 运算 外 ， 
还 可 以 进行 逻辑 运算 ， 因 为 它 只 有 两 个 数码 ， 可 以 代表 两 种 截然 相反 
的 状态 。 本 市 将 分 别 介绍 二 进 制 数 的 四 则 算术 运算 和 逻辑 运算 。 


1.3.1 二进制 四 则 算术 运算 
二 进 制 数 的 加 、 减 、 乘 、 除 四 则 算术 运算 法 则 其 实 与 十 进 制 数 的 


四 则 算术 运算 法 则 是 一 一 对 应 的 。 理 解 了 十 进 制 数 的 四 则 算术 运算 法 
则 ， 二 进 制 数 的 四 则 算术 运算 就 一 点 都 不 难 了 。 下 面 分 别 予 以 介绍 。 


1. 加 、 减 法 运算 


首先 要 了 解 二 进 制 的 加 、 减法 运算 法 则 。 


(1) 加 法 运算 法 则 


0+0=0，0+1=1，1+0=1，1+1=10， 也 就 是 当 两 个 相 加 的 二 进 制 位 
仅 一 位 为 1 时 ， 相 加 的 结果 为 1， 如 果 两 个 二 进 制 位 全 是 0， 相 加 的 结 
仍 为 0， 而 如 果 两 个 相 加 的 二 进 制 位 均 为 1， 则 结果 为 10 (相当 于 十 进 
制 中 的 2) ， 也 就 是 “ 逢 2 进 1 规则 ， 与 十 进 制 中 的 * 逢 10 进 1 的 道理 一 
样 。 


在 进行 二 进 制 加 减法 运算 时 ， 最 关键 的 一 点 就 是 着 2 进 1， 进 1 当 
1， 而 借 1 当 2。 大 家 联想 一 下 我 们 经 常 使 用 的 十 进 制 数 加 法 运算 法 则 ， 
那 就 是 着 10 进 1， 进 1 当 1， 而 借 1 当 10， 这 样 一 来 我 们 就 好 理解 了 。 二 
进 制 数 的 加 法 运算 法 则 只 是 把 原来 十 进 制 数 加 法 运算 法 则 中 的 10 改 成 
本 了 3 


计算 (10010), +(11010), 的 过 程 如 图 1-11 所 示 (注意 两 数 要 从 最 低 
位 开始 对 齐 ) 。 


被 加 数 ed - 定 要 从 
加 数 11010 | 最 低位 开始 一 位 位 地 对 齐 


进位 1 1 
十 


101100 


1-11 二 进 制 加 法 运算 示例 


1) 首先 是 进行 最 低位 相 加 ， 这 里 加 数 和 被 加 数 都 为 “0”， 根 据 加 
法 法 则 可 以 知道 ， 相 加 后 为 “0”; 


2) 再 进行 倒数 第 二 位 相 加 ， 这 里 加 数 和 被 加 数 都 为 "1”， 根 据 加 
法 法 则 可 以 知道 ， 相 加 后 为 “(10), ”"， 此 时 把 后 面 的 “0” 留 下 ， 而 把 第 


一 位 的 “12?” 回 高 一 位 进 “1?”; 


3) 再 进行 倒数 第 三 位 相 加 ， 这 里 加 数 和 被 加 数 都 为 “0”， 根 据 加 
法 法 则 可 以 知道 ， 本 来 结果 应 为 "0”， 但 倒 第 二 位 已 向 这 位 进 “1> 了 ， 
此 时 就 要 同时 把 “被 加 数 ”\“ 加 数 " 和 * 进 位 ”这 三 个 数 加 起 来 了 ， 所 以 
结果 应 为 0+0+1=1; 


4) 再 进行 倒数 第 四 位 的 相 加 ， 这 里 加 数 和 被 加 数 分 别 
为 “1” 和 “0”， 倒 数 第 三 位 也 没有 进位 ， 根 据 加 法 法 则 可 以 知道 ， 相 加 
后 为 <1” 


5) 最 后 是 最 高 位 相 加 ， 这 里 加 数 和 被 加 数 都 为 <1”"， 根 据 加 法 法 
则 可 以 知道 ， 相 加 后 为 “(10)，,。 ”。 同样 需 把 第 一 位 的 “0” 留 下 ， 并 向 融 
位 进 1， 这 样 会 产生 新 的 最 高 位 ， 值 为 4” (如 果 超 出 了 字 长 的 限制 ， 
则 新 产生 的 最 高 位 将 洲 出 ) 。 


这 样 (10010), +(11010); 的 最 后 运算 结果 为 101100。 


(2) 减法 运算 法 则 


1-1=0，1-0=1，0-0=0，0-1=-1， 也 丈 是 当 两 个 相 加 的 二 进 制 位 中 
同 为 0 或 1 时 ， 相 减 的 结果 为 0， 如 果 被 减 数 的 二 进 制 位 为 1， 而 减 数 的 
二 进 制 位 为 0， 则 相 减 的 结果 仍 为 1， 而 如 果 被 减 数 的 二 进 制 位 为 0， 而 
减 数 的 二 进 制 位 为 1， 则 需要 向 高 位 借 1， 但 此 时 是 借 1 当 2， 与 十 进 制 
中 的 借 1 当 10 道 理 一 样 。 


计算 (111010), -(101011), 的 过 程 如 图 1-12 所 示 (注意 两 数 要 从 最 
低位 开始 对 齐 ) 。 


被 减 数 tnd en ei 
减 数 ”101011 】 最 低位 开始 一 位 位 地 对 章 
借 位 1111 


00111] 
1-12 二进制 减法 运算 示例 
1) 首先 是 最 低位 相 减 ， 这 里 被 减 数 为 “0”"， 减 数 为 “<1”， 不 能 直接 
相 减 ， 需 要 癌 高 位 (此 时 为 倒数 第 二 位 ) 借 “1”"， 这 样 相当 于 得 到 了 十 
进 制 中 的 “2”， 用 2 减 1 结果 就 得 到 1。 


2) 再 对 倒数 第 二 位 相 减 ， 此 时 本 来 被 减 数 和 减 数 均 为 “1”， 但 是 
被 减 数 的 该 位 被 上 一 步 借 走 了 1， 所 以 最 后 就 变 为 “0”(1-1) 了 。 此 时 
也 不 能 直接 与 减 数 相 减 了 ， 又 需要 向 高 位 〈 此 时 为 倒数 第 三 位 ) 借 1。 


同样 是 借 1 当 2， 相 当 于 该 位 总 共 为 0+2=2。 这 样 倒数 第 二 位 相 减 后 的 
结果 为 2-1=1 。 


3) 用 上 一 步 同样 的 方法 计算 倒数 第 三 位 和 倒数 第 四 位 的 减法 运 
算 ， 结 果 都 为 1。 

4) 再 计算 倒数 第 五 位 的 减法 运算 ， 此 时 被 减 数 原来 为 "1”， 可 是 
已 被 倒数 第 四 位 借 走 了 1， 所 以 成 了 “0” (1-1) ， 而 此 时 减 数 也 
为 “0”"， 可 以 直接 相 减 ， 得 到 的 结果 为 “0”。 


5) 最 后 计算 最 高 位 的 相 减 ， 被 减 数 和 减 数 均 为 “1”"， 可 以 直接 相 
减 ， 得 到 的 结果 为 “0”。 

这 样 一 来 ，(111010), -(101011), 的 结果 是 (001111)。， 由 于 整数 的 
前 导 0 可 以 不 写 ， 所 以 最 后 结果 就 是 (1111)，。 


2. 乘 、 除 法 运算 
同样 ， 首 先 要 了 解 二 进 制 的 乘 、 除 法 运算 法 则 。 
(1) 乘法 运算 法 则 


0x0=0，0xl=0，1x0=0，1x1=1， 也 就 只 有 当 两 个 相 乘 的 二 进 制 位 
都 为 1， 相 乘 的 结果 才 为 1， 两 个 相 乘 的 二 进 制 位 中 只 要 有 一 位 为 0 (也 
包括 是 两 位 同时 为 0) ， 则 相 乘 的 结果 都 为 0。 也 可 以 这 么 理解 : 1 与 任 


何 数 相 乘 的 结果 藉 是 对 应 的 被 乘 数 ;而 0 与 任何 数 相 乘 的 结果 都 为 0。 
这 与 十 进 制 中 的 乘法 运算 法 则 也 十 一 样 的 。 要 注意 的 是 ， 在 乘法 运算 
中 ， 乘 数 的 每 一 位 要 与 被 乘 数 的 每 一 位 分 别 相 乘 ， 而 不 仅 是 对 应 位 相 
乘 ， 而 且 乘 数 的 每 一 位 与 被 乘 数 的 每 一 位 相 乘 的 结果 的 最 低位 要 与 对 


应 的 乘 数位 对 齐 。 当 然 这 与 十 进 制 的 乘法 运算 法 则 也 是 一 样 的 ， 很 好 
理解 。 


计算 (1010), x(101), 的 过 程 如 图 1-13 所 示 (注意 两 数 要 从 最 低位 开 
台 对 齐 ) 。 


被 乘 数 1010 


乘 数 101 
xX 
1010 | z 
0000 这 里 每 行 的 最 低位 一 定 
. 1010 
积 110010 


图 1-13 二 进 制 乘法 运算 示例 
1) 首先 是 乘 数 的 最 低位 与 被 乘 数 的 所 有 位 相 乘 ， 因 为 乘 数 的 最 低 
位 为 “1”， 根 据 乘法 法 则 可 以 得 出 ， 结 果 其 实 就 是 被 乘 数 本 身 ， 直 接 复 
制 下 来 即 可 。 此 处 结果 就 为 1010。 


2) 接着 进行 的 是 乘 数 的 倒数 第 二 位 与 被 乘 数 的 所 有 位 相 乘 ， 因 为 
乘 数 的 这 一 位 为 “0”"， 根 据 乘 法 运算 法 则 可 以 得 出 ， 结 采 均 为 “0”。 此 
处 结 采 就 为 0000。 


3) 然后 是 乘 数 的 最 高 位 与 被 乘 数 的 所 有 位 相 乘 ， 此 时 乘 数 
为 “1”， 结 果 束 十 补 乘 数 本 喘 。 此 处 结 末 束 为 1010 。 


4) 最 后 再 按照 前 面 介绍 的 二 进 制 加 法 原则 对 以 上 三 步 所 得 的 结 
按 位 相 加 (但 这 里 的 位 对 齐 方 式 与 单纯 的 二 进 制 数 相 加 不 一 样 ， 最 低 
位 一 定 要 与 对 应 乘 数 位 对 齐 。 这 也 与 十 进 制 的 乘法 运算 方法 一 样 )， 
结果 得 到 (110010)，。。 


(2) 除法 运算 法 则 


当 被 除数 大 于 除数 时 ， 商 是 “1”， 当 被 除数 小 于 除数 时 ， 不 够 除 ， 
商 只 能 是 “0”， 这 与 十 进 制 的 除法 也 类 似 。 二 进 制 只 有 两 个 数 (0， 
1) ， 因 此 它 的 商 也 只 能 是 1 或 0。 


计算 (11001), :(101), 的 过 程 如 图 1-14 所 示 。 


商 101 
除数 101 上) 11001 被 除数 


一 101 
101 

一 101 
000 


图 1-14 二 进 制 除法 运算 示例 


1) 因为 除数 为 “101”"， 有 3 位 ， 所 以 在 被 除数 中 也 至 少 要 取 3 位 
(从 最 高 位 开始 取 ) 。 被 除数 的 高 3 位 为 “110”"， 恰 好 比 除数 “101” 大 ， 
可 以 直接 相 除 ， 但 商 只 能 是 1 (因为 二 进 制 的 最 大 数 元 就 是 1) ， 然 后 
把 被 除数 减法 商 “1” 与 除数 相 乘 后 的 结果 ， 得 到 的 值 为 “1”。 


2) 再 从 被 除数 中 取 下 一 位 “0” 下 来 ， 与 上 一 步 的 差 “1” 值 组 成 新 的 
被 除数 ， 为 "10”， 显 然 它 比 除数 “101" 小 ， 不 够 除 。 于 是 在 商 的 对 应 位 
置 上 输入 “0”。 


3) 继续 从 被 除数 中 取 下 一 位 1” 下来， 与 上 一 步 的 余数 “10” 值 组 
成 新 的 被 除数 ， 为 “101”， 此 数 正好 与 除数 “101” 相 等 ， 所 以 此 时 的 商 
取 “1”， 正 好 除 尽 。 


这 样 一 来 (11001), *(101)> 所 得 的 商 就 是 101) 了 。 


3. 同 步 练习 

1) 求 (011101)B+(10010)B、(100111)B+(110110)B 的 值 ; 
2) 求 (1110101)B-(110010)B、(1101011)B-(10001)B 的 值 ; 
3) 求 (1110)Bx(1001)B、(1100)Bx(10111)B 的 值 ; 


4) 求 (110010)B*(1010)B、(100110101011)B=(1011)B 的 值 。 


1.3.2 二进制 逻辑 运算 


罗 辑 运算 是 指 对 因果 关系 进行 分 析 的 一 种 运算 ， 这 也 是 在 计算 机 
中 经 常 采用 的 一 种 二 进 制 运算 。 逻 辑 运算 的 结果 并 不 表示 数值 大 小 ， 
而 是 表示 一 种 逻辑 概念 ， 若 成 立 则 为 " 真 "， 或 用 “1* 表 示 ， 若 不 成 立 ， 
则 为 “ 假 "， 或 用 “0” 表 示 。 二 进 制 的 逻辑 运算 主要 
有 “与 "、“ 或 "、“ 非 "和 “ 异 或 "四 种 。 


1* 与 ”运算 (AND) 


“与 ”运算 勾 称 逻辑 乘 ， 用 符号 “…” 或 “A” 来 表示 。 运 算法 则 如 下 : 


0A0=0 0A1=0 1A0=0 1A1=1 


归纳 起 来 也 殊 是 在 “与 运算 中 ， 只 要 两 个 参加 “与 ”运算 的 数 的 对 
应 位 有 一 个 为 0， 运 算 结果 束 为 0， 仪 当 两 数 的 对 应 位 均 为 1 时 结果 才 为 
1， 很 容易 判断 。 这 与 前 面 介 绍 的 二 进 制 乘法 运算 是 一 样 的 。 图 1-15 所 
示 是 两 个 “与 ”的 逻辑 运算 示例 。 图 1-15a 所 示 的 是 两 个 位 数 不 一 样 的 二 
进 制 数 进行 “与 ”运算 ， 这 时 要 求 两 个 数 从 最 低位 开始 对 齐 ， 在 位 数 少 
的 二 进 制 的 最 高 位 前 面 加 上 “0” 补 齐 ， 使 得 它 与 位 数 多 的 二 进 制 数 有 一 
样 的 位 数 。 


补 的 “0> 10011 11110110 


A ol00l A 11011101 
00001 11010100 
a ) b ) 


1-15 ”两 个 “与 ”逻辑 运算 示例 
2.“ 或 "运算 (OR) 
“或 ”运算 又 称 罗 辑 加 ， 用 符号 “+? 或 <v” 表 示 。 运 算法 则 如 下 : 


OV0O=0 OV1=1 1vVO=1 1vV1=1 


也 束 是 说 ， 在 “或 ”运算 中 ， 只 要 两 个 参加 “或 ”运算 数 的 对 应 位 中 
有 一 个 为 1， 运 算 结 末了 束 为 1， 仅 当 两 数 的 对 应 位 均 为 0 时 结果 才 为 0， 
也 很 容易 判断 。 如 图 1-16 所 示 十 两 个 “或 ”的 逻辑 运算 示例 。 同 样 ， 进 
行 “ 或 "运算 时 要 求 两 数 从 最 低位 开始 对 齐 ， 位 数 少 的 数 在 最 高 位 前 面 
加 “0” 补 齐 ， 最 终 使 两 个 二 进 制 数 的 位 数 相同 。 


补 的 “0” 1001110 100101010 
Vy 0110110 V 100111100 
1111110 100111110 


a ) b ) 


1-16 ”两 个 “或 ”逻辑 运算 示例 
Sm MOT 
“ 非 ” 运 算 就 是 逐 位 求 反 的 运算 ， 其 运算 法 则 为 :“0” 的 反 值 
为 “<1”，“1” 的 反 值 为 “0”"， 也 就 是 “0” 与 “1” 互 为 反 。 注 意 :“ 非 运算 ”只 


是 针对 一 个 二 进 制 数 进行 的 ， 这 与 前 面 的 “与 “和 “或 ”运算 不 一 样 。 
如 “101110101” 进 行 “ 非 ”运算 后 就 得 到 “010001010”( 可 简写 


为 “10001010”) 。 


4.“ 异 或 ”运算 (XOR) 


“ 异 或 "运算 用 符号 “<@” 来 表示 。 其 运算 法 则 如 下 


0@0=0 0@®1=1 1@90=1 1®@1=0 


也 就 是 说 ， 当 两 个 参加 “ 异 或 "运算 的 二 进 制 数 对 应 位 相同 时 运算 
结果 为 0， 不 同时 运算 结果 为 1°。 图 1-17 所 示 是 “ 异 或 "逻辑 运 滤 示例 。 
同样 ， 进 行 “ 异 或 ”运算 时 要 求 两 数 从 最 低位 开始 对 齐 ， 位 数 少 的 数 在 
最 高 位 前 面 加 “0” 补 齐 ， 最 终 使 两 个 二 进 制 数 的 位 数 相同 。 


补 的 “0” 1001110 100101010 


中 0110110 @ 100111100 
1111000 000010110 
a ) b ) 


1-17 ”两 个 “ 异 或 "逻辑 运算 示例 
5. 同 步 练习 
1) 求 (11001)BA(1011)B、(10011)BA(10101)B 的 结果 ; 
2) 求 (11001)BV(1011)B、(10011)BV(10101)B 的 结果 ; 
3) 求 (1100110)B、(1000111)B 非 的 结果 ; 


4) 求 (1100110)B@(1011)B、(100111)B@(10101)B 的 结 


1.4 二进制 数 的 表示 形式 


结束 了 以 上 各 种 进 制 数 之 则 的 转换 ， 我 们 来 谈 谈 男 一 个 话题 ， 原 
码 、 反 码 、 补 码 和 移 码 。 其 实 它们 都 是 计算 机 中 二 进 制 数 〈 称 之 为 “机 
器 数 ”) 的 不 同 表示 形 式 ， 之 所 以 会 有 这 么 多 码 ， 最 根本 的 原因 就 是 计 
算 机 只 有 加 法 运算 器 ， 减 法 运算 需要 转换 成 负数 的 加 法 。 这 里 又 出 现 
一 个 问题 ， 那 吏 是 计算 机 如 何 来 识别 负数 ? 因为 它 不 能 像 人 的 大 脑 一 
样 可 以 识别 *+”、“-” 之 类 的 符号 ， 故 必须 用 一 个 专门 的 位 来 表示 数 的 
符号 ， 这 就 古 计算 机 中 的 “有 符号 数 ” 的 由 来 。 


我 们 已 经 知道 ， 计 算 机 中 所 有 数据 最 终 部 是 使 用 二 进 制 数 表示 
的 。 我 们 也 已 经 学 会 如 何 将 一 个 十 进 制 、 八 进 制 和 十 六 进 制 数 转换 为 
二 进 制 数 ， 但 我 们 仍然 不 知道 如 何 将 一 个 负数 用 二 进 制 形式 来 表示 ， 
因为 我 们 前 面 学 习 的 都 是 针对 正 数 的 ， 无 论 征 整数， 还 是 小 数 。 其 
实 ， 在 计算 机 中 负数 是 以 其 正 数 的 补 码 形式 表示 的 ， 这 就 古本 市 所 要 


介绍 的 主题 。 


1.4.1 ”二进制 数 的 真 值 和 字 长 


前 面 说 了 ， 负 数 是 通过 其 正 数 的 补 码 形式 来 表示 的 ， 那 什么 征 补 
码 呢 ?这 还 得 从 原 码 、 反 码 说 起 。 在 计算 机 二 进 制 数 中 其 实 也 包括 符 


号 位 ， 并 不 是 所 有 位 者 代表 数据 本 身 ， 束 像 我 们 常用 的 十 进 制 数 中 有 
正 、 有 人 负 一 样 。 但 是 二 进 制 中 没有 “-” 这 个 符号 ， 那 么 计算 机 中 的 机 器 
数 的 符号 是 怎样 规定 的 呢 ? 这 得 从 机 器 数 的 两 个 基本 概念 ( 真 值 和 字 
长 ) 说 起 。 


(1) 真 值 


计算 机 中 的 二 进 制 机 器 数 分 为 * 有 符号 数 " 和 “无 符号 数 "两 种 。“ 无 
从 号 数 * 就 是 二 进 制 数 的 每 一 位 都 代表 对 应 位 的 数值 ， 而 在 “有 符号 
数 ” 中 规定 最 高 位 用 来 表示 数据 符号 ， 其 中 1 代表 负 ，0 代 表 正 ， 这 样 一 
来 机 器 数 本 身 就 不 等 于 真正 的 数值 了 。 例 如 有 符号 数 10000101， 其 最 
高 位 1 代表 负 ， 所 以 余下 的 “0000101” 才 是 数值 本 身 ， 所 以 其 真正 数值 
是 -5， 而 如 果 是 无 符号 数 ， 则 10000101 所 代表 的 是 133。 为 区 别 起 见 ， 
把 带 符 号 位 的 机 器 数 所 对 应 的 真正 数值 称 为 机 器 数 的 * 真 值 ”。 例 : 
00100001 的 真 值 =0 0100001=+33 〈 正 号 可 以 不 写 ， 可 以 直接 写成 
33) ，10100011 的 真 值 =1 0100011=-35 。 


(2) 字 长 


在 机 器 数 中 还 有 一 个 概念 需要 首先 弄 明 白 ， 那 就 是 “ 字 长 *"。“ 字 
"是 指 计算 机 一 次 可 处 理 的 二 进 制 数 的 码 位 长 度 ， 是 计算 机 进行 数据 
存储 和 数据 处 理 的 运算 单位 。 如 我 们 通常 所 指 的 32 位 处 理 器 ， 就 是 指 


该 处 理 右 的 字 长 为 32 位 ， 也 就 古 一 次 能 处 理 32 位 二 进 制 数 。 通 常 称 16 


位 是 一 个 字 ，32 位 是 一 个 双 字 ，64 位 是 两 个 双 字 。 


数值 的 转换 结果 是 与 字 长 有 关 的 。 如 果 计 算 机 字 长 为 8 位 ， 十 进 制 
中 的 数 +5 转 换 成 二 进 制 就 是 00000101，-5 转 换 成 二 进 制 就 是 
10000101; 但 如 果 字 长 是 16 位 ，+5 转 换 的 结果 就 是 00000000 
00000101， 而 -5 转换 成 二 进 制 就 是 10000000 00000101 了 “。 也 就 是 对 应 
的 机 器 数 要 转换 为 字 长 所 代表 的 位 数 。 


字 长 越 长 代表 计算 机 的 处 理 能 力 越 强 ， 可 以 处 理 的 数 越 大 。 如 现 
在 字 长 普遍 是 64 位 的 了 ， 这 样 一 来 计算 机 可 以 处 理 的 二 进 制 数码 位 长 
度 最 大 为 64 位 ， 去 掉 符 号 位 ， 则 表示 计算 机 可 以 处 理 的 最 大 二 进 制 数 
为 2 的 63 次 方 ， 最 小 二 进 制 数 就 是 -2 的 63 次 方 。 而 在 8 位 字 长 中 ， 因 为 
最 高 位 要 用 于 符号 位 ， 所 以 实际 可 以 处 理 的 数值 大 小 范围 
为 -127~-0~0~127 ( 即 27 -1) ， 共 256 个 数 了 ; 但 如 果 字 长 是 16 位 ， 可 


以 处 理 的 数值 大 小 就 可 以 是 -32677~-0~0~32767(22 -1)。 


注意 ”以 上 的 “-0” 与 “0” 的 机 器 数 是 不 一 样 的 ， 在 8 位 字 长 中 ，-0 为 
1 0000000， 而 +0 为 0 0000000; 在 16 位 字 长 中 ，-0 为 1 0000000 
00000000， 而 +0 为 0 0000000 00000000。 所 以 在 二 进 制 的 机 器 数 中 ，0 
也 有 两 个 (-0 和 0) ， 且 表示 形式 并 不 一 样 。 


1.4.2 二进制 效 的 四 种 表示 形式 


计算 机 中 的 二 进 制 数 有 四 种 主要 表示 形式 ， 那 就 是 原 码 、 反 码 、 
补 码 和 移 码 ， 其 中 最 重要 的 是 前 三 种 。 反 码 和 补 码 是 为 了 在 二 进 制 中 
表示 人 负数 而 产生 的 。 本 市 具体 介绍 这 四 种 表示 形式 。 要 注意 的 是 ， 采 
用 哪 种 表示 形式 ， 运 算 的 结果 也 是 对 应 的 表示 形式 。 


1. 原 公 


对 于 人 脑 来 说 ， 我 们 都 知道 ，+ 表 示 正 数 ，- 表 示人 负数 ， 然 而 在 计 
算 机 二 进 制 中 也 引入 这 两 个 符号 肯定 是 不 行 的 ， 因 为 在 计算 机 中 只 有 0 
和 1 这 两 个 字 ， 根 本 不 认识 “+” 和 “-” 这 两 个 符 和 号。 计算机 中 的 任何 行为 
都 依赖 于 它 的 物理 结构 。 计 算 机 是 没有 思维 的 ， 所 以 得 让 计算 机 在 0 和 
1 之 间 识 别 出 对 应 数 的 正 与 负 。 


最 开始 的 时 候 ， 人 们 约定 在 一 个 二 进 制 数 前 用 第 一 位 (最 高 位 ) 
来 表示 符号 ， 即 1 表示 仙 ，0 表 示 正 ， 这 束 是 最 初 “ 原 码 ” 的 概念 。“ 原 
码 ” 束 古 “ 原 始 码 位 *"， 或 者 “原始 编码 ”的 意思 ， 束 古 对 应 二 进 制 数 本 号 
所 代表 的 形式 。 比 如 ，+3 (以 8 位 字 长 为 例 ， 下 同 ) ， 符 号 位 为 0，3 
转化 为 二 进 制 束 是 11， 那 么 +3 的 原 码 束 是 00000011 (最 高 位 为 符号 
位 ， 正 数 的 符号 位 为 “0”"， 其 余数 值 位 不 足 部 分 人 0) 。 同 理 ，-3 的 符 
写 位 为 1，3 转 化 为 二 进 制 束 古 11， 最 终 -3 的 原 码 束 是 10000011 〈 不 足 8 


位 时 在 前 面 用 0 补足 ) 。 在 日 常 的 书写 中 ， 原 码 的 表示 形式 是 用 方 括号 
下 面 加 上 一 个 “ 原 ” 字 下 标 来 区 别 的 ， 如 [+3] 原 =00000011，[-3] 原 
=10000011 。 


再 来 计算 +127 和 -127 各 自 的 原 码 。+127 中 符号 位 为 “0”，127 的 二 
进 制 为 "1111111”， 这 样 [+127] 原 =01111111; 而 -127 中 的 符号 位 也 


为 “1”， 所 以 最 终 [-127] 原 =11111111 。 


最 应 该 注意 的 是 ， 在 原 码 表示 形式 中 ，0 有 “+0” 和 “-0” 之 分 。 对 应 
的 原 码 分 别 是 0 0000000 和 1 0000000。 


2. 补 码 


原 码 的 设计 很 不 错 ， 至 少 可 以 成 功 地 区 分 出 二 进 制 数 的 正 与 负 
了 ， 但 古 这 种 方法 仍 有 一 些 局 限 性 ， 那 束 是 原 码 在 加 、 减 法 运算 中 不 
方便 ， 符 号 位 需要 单独 处 理 、 单 独 判 灯 。 同 为 正 数 的 加 、 诚 是 没什么 
问题 的 ， 可 古 异 号 相 加 、 减 时 束 存 在 问题 了 。 如 1-1， 如 采用 原 码 计 算 
的 话 结果 为 -2， 显 然 不 正确 。 


(0 0000001) 原 +(1 0000001) 质 =(1 0000010) 皮 =-2 


另外， 在 原 码 中 0 有 +0 和 -0 两 种 表示 形式 ， 这 束 存 在 二 义 性 了 ， 在 
计算 机 中 十 绝对 不 能 容忍 的 。 于 是 后 来 孢 想到 一 种 能 解决 原 码 中 存在 
的 这 些 问 题 的 态 一 种 表示 形式 一 一 补 码 。 


补 码 的 编码 规则 如 下 : 正 数 的 补 码 和 原 码 相同 ， 负 数 的 补 码 是 通 
过 先 把 除 符号 位 外 其 他 各 位 取 反 ， 再 在 末 位 (最 低位 ) 加 1 得 到 的 。 这 
样 ， 我 们 只 要 让 减 数 通过 一 个 求 反 电路 ， 再 通过 一 个 +1 电 路 ， 然 后 再 
通过 加 法 器 就 可 以 实现 减法 运算 了 。 


经 验 之 谈 ”如 果 要 把 一 个 补 码 转换 成 原 码 该 如 何 操作 呢 ? 很 商 
单 ， 只 需要 把 原 码 转换 成 补 码 的 过 程 倒 过 来 操作 就 行 了 。 因 为 正 数 的 
补 码 与 原 码 一 样 ， 所 以 正 数 补 码 的 原 码 束 古 其 补 码 ， 而 负数 补 码 的 原 
码 是 移 在 最 后 一 位 加 1， 然 后 对 其 除 符号 位 外 的 其 他 各 位 全 部 取 反 得 
到 。 只 有 相同 码 制 的 数 才 能 进行 操作 ， 结 末 束 是 对 应 的 码 制 ， 也 融 是 
原 码 数 与 码 数 的 运算 ， 结 果 也 为 原 码 ， 反 码 数 与 反 码 数 的 运算 结 采 也 
为 反 码 ， 补 码 数 与 补 码 数 的 运算 结果 也 为 补 码 。 如 果 结 果 是 负数 ， 要 
判断 结果 是否 正确 ， 需 要 再 将 其 对 应 的 码 制 转换 为 原 码 。 


补 码 首先 继承 了 原 码 的 特点 (可 以 表示 正 与 负 ) ， 而 且 它 包括 了 
两 个 优点 : 


口 可 以 把 符号 位 一 起 运算 ; 


D0 只 有 一 种 表示 形式 ,没有 二 义 性 。 


下 面 同样 以 上 面 的 1-1 为 例 ， 如 有 果 采 用 补 码 形式 ， 则 算式 如 下 : 


(0 0000001) 补 +(1 1111111) 补 =0 0000000=0 


结 采 完全 正确 。 其 实 这 里 涉及 一 个 计算 机 运算 中 “ 模 ” 的 概念 。 


我 们 把 一 个 计量 单位 称 为 模 或 模 数 。 例 如 ， 时 钟 是 以 十 二 进 制 进 
行 计数 循环 的 ， 即 以 12 为 模 。 在 时 钟 上 ， 时 针 加 上 《〈 正 拨 ) 12 的 整数 
倍 或 减 去 〈 反 拨 ) 12 的 整数 倍 ， 时 针 的 位 置 不 变 。 例 如 ，14 点 钟 在 使 
去 模 12 后 ， 成 为 下午 ) 2 点 钟 (14=14-12=2) ; 从 0 点 出 发 逆 时 针 拨 
10 格 即 减 去 10 小 时 ， 也 可 看 成 从 0 点 出 发 顺 时 针 拨 2 格 (加 上 2 小 时 ) ， 
即 2 点 (0-10=-10=-10+12=2) 。 因 此 ， 在 模 12 的 前 提 下 ，-10 可 映射 为 
十 2 。 


由 此 可 见 ， 对 于 一 个 模 数 为 12 的 循环 系统 来 说 ， 加 2 和 减 10 的 效果 
是 一 样 的 。 所 以 ， 在 以 12 为 模 的 系统 中 ， 凡 是 减 10 的 运算 都 可 以 用 加 2 
来 代替 ， 这 样 就 把 减法 问题 转化 成 加 法 问题 了 ( 注 : 计算 机 的 硬件 结 
构 中 只 有 加 法 器 ， 所 以 大 部 分 的 运算 都 必须 最 终 转 换 为 加 法 ) 。10 和 2 
对 模 12 而 言 互 为 补 数 。 


同 理 ， 计 算 机 的 运算 部 件 与 寄存 器 部 有 一 定 字 长 的 限制 ， 因 此 它 
的 运算 也 是 一 种 模 运 算 。 如 采 字 长 为 ， 则 当 计 数 历 计 满 8 位 也 束 是 256 
个 数 后 会 产生 淤 出 ， 又 从 头 开始 计数 。 产 生 溢 出 时 的 那个 量 束 是 计数 
妖 的 模 。 显 然 ，8 位 二 进 制 数 的 模 数 为 2 的 8 次 方 ， 即 256。 在 计算 中 ， 
两 个 互补 的 数 称 为 “ 补 码 *”， 这 殊 是 “ 补 码 ”表示 形式 诞生 的 由 来 。 


十 进 制 数 2-3=(0 0000010) 补 +(1 1111101) 补 =(11111111) 补 =-1， 也 是 
正确 的 。 十 进 制 数 123-121=(0 1111011) 补 +(1 0000111) 补 =(0 0000010) 补 
=2， 也 征 正 确 的 。 


另外 ， 在 补 码 表示 形式 中 ，0 仅 有 一 种 表示 形式 ， 因 为 无 论 
是 “+0”， 还 是 “-0” 的 补 人 码 均 为 0 0000000。 


3. 肥 码 


通过 以 上 介绍 ， 我 们 可 以 知道 ， 补 码 是 我 们 的 最 佳 选 择 ， 因 为 它 
可 以 全 面 解决 异 号 二 进 数 之 间 的 加 减 运算 问题 。 那 为 什么 还 有 “有 反 
码 ” 这 种 表示 形式 呢 ? 其实 “ 反 码 ” 是 “ 原 码 ” 同 “ 补 码 ” 表 示 形 式 转变 过 程 
中 的 一 个 过 渡 形 式 ， 最 终 证 明 它 是 失败 的 。 之 所 以 当初 会 想到 “ 反 
码 ”， 是 因为 它 太 容易 从 电路 上 来 实现 了 ( 仅 需 要 取 反 就 行 了 ) 
但 “ 反 码 "专门 是 针对 负数 进行 的 〈 正 数 的 反 码 与 原 码 一 样 ) ， 束 是 对 
二 进 制 负数 按 位 〈 除 符号 位 外 ) 取 反 ， 原 来 为 1 就 变 为 0， 原 来 为 0 就 变 
为 1。 而 且 采 用 反 码 形式 对 于 一 些 异 号 二 进 制 运算 还 是 正确 的 ， 如 上 面 
所 说 的 “2-3”， 采 用 反 码 运算 的 格式 如 下 : 


(0 0000010) 反 +(1 1111100) 反 =(1 1111110) 反 =-1 
但 是 在 1-1 的 反 码 运 算 中 ， 结 果 束 不 正确 了 : 


(0 0000001)E +(1 1111110) 反 =(1 1111111) 反 =-0 


本 来 应 该 是 +0 的 ， 结 果 却 成 了 -0。 
再 如 十 进 制 数 “123-121”， 用 反 码 加 法 运算 就 得 到 : 
(0 1111011) 上 +(1 0000110)z =(0 0000001) 反 =1 


显然 也 不 正确 。 


注意 ” 反 码 是 相互 的 ， 如 10011001 的 反 码 为 11100110 (符号 位 是 
不 变 的 ) ， 相 反 11100110 的 反 码 也 是 10011001。 另 外 ， 与 原 码 一 样 ， 
在 反 码 表示 形式 中 0 也 有 “+0” 和 “-0” 之 分 ， 对 应 的 反 码 分 别 为 0 0000000 
和 1 1111111 。 


综 上 可 以 得 出 : 正 数 的 原 码 、 反 码 和 补 码 都 是 一 样 的 ， 而 负数 的 
这 三 种 表示 形式 束 不 一 样 了 ， 人 负数 的 反 码 钙 对 原 码 中 除 符号 位 外 的 其 
他 各 位 取 反 ， 而 负数 的 补 码 是 再 对 其 反 码 加 1， 也 就 是 和 完 对 其 原 码 中 除 
符号 位 外 的 其 他 各 位 取 反 ， 然 后 再 在 最 低位 加 1。 


4. 移 公 


移 码 是 一 种 比较 特殊 的 二 进 制 数 表 示 形 式 。 它 的 编码 规则 如 下 : 


口 正 数 的 符号 位 为 1， 负 数 的 符号 位 为 0 


口 真 值 部 分 与 补 码 一 样 。 


从 以 上 两 个 编码 规则 中 可 以 看 出 ， 要 求 一 个 二 进 制 数 的 移 码 ， 只 
需 先 求 出 它 的 补 码 ， 然 后 再 把 符号 位 取 反 (因为 在 补 码 中 规定 符号 位 1 
表示 负数 ，0 为 正 数 ， 正 好 相反 ) 就 行 了 ， 所 以 移 码 又 称 为 符号 位 取 反 
的 补 码 。 如 : 5 的 二 进 制 移 码 (假设 字 长 为 8) 为 10000101，-5 的 二 进 
制 移 码 为 01111011 〈 它 是 对 -5 的 补 码 符号 取 反 的 结果 ) 。 


其 实 还 有 一 种 更 简单 的 计算 移 码 的 方法 ， 那 就 是 [X] 移 =2 的 n 次 方 
为 二 进 制 数 的 位 数 ， 不 包括 符号 位 ) 的 二 进 制 值 +X。 如 [-11010] 移 
=[25 ]B+(-11010)=1000000-11010=000110。 现 在 我 们 再 来 利用 上 面 所 介 
绍 的 补 码 符号 位 取 反 的 方法 来 重新 计算 一 下 ， 验 证 以 上 结果 是 否 正 

确 。 


[-11010]B 的 补 码 为 100110， 符 号 位 取 反 后 得 到 000110， 最 后 证 明 
两 种 算法 结果 一 样 。 


1.4.3” 补 码 的 加 减法 运算 


上 市 介绍 了 原 码 、 反 码 、 补 码 和 移 码 的 转换 方法 ， 同 时 我 们 知 
道 ， 在 计算 机 机 需 数 中 实际 上 全 有 是 采用 补 码 方式 进行 运算 的 ， 特 别 是 
减法 运算 。 因 为 原 反 和 反 码 的 减法 运算 有 时 结 采 是 不 正确 的 。 所 以 本 
节 仅 介绍 补 码 的 加 、 减 法 运算 方法 。 


1. 补 码 的 转换 


在 正式 介绍 促 码 的 加 减法 运算 前 ， 还 是 先 回 顾 一 下 补 码 的 运算 廊 
法 ， 这 是 补 码 运算 的 基础 。 通 过 前 面 的 学 习 ， 我 们 知道 ， 机 硕 数 的 补 
码 可 由 原 码 和 反 码 得 到 。 如 条 机 套数 旦 正 数 ， 则 该 机 需 数 的 补 码 与 原 
码 一 样 ， 如 果 机 器 数 古 负数 ， 则 该 机 右 数 的 补 码 是 对 它 的 反 码 在 未 位 
加 1 而 得 到 的 。 


例如 ， 当 X=+0.1011 时 ， 根 据 以 上 规则 可 得 到 [X] =0.1011 (因为 
正 数 的 补 码 与 原 码 、 补 码 一 样 ) 。 而 当 X=-0.1011 时 ， 则 [又 ] 补 =1.0101 
(负数 的 补 码 是 符号 位 不 变 ， 真 值 是 在 它 的 反 码 基础 上 最 后 位 加 1 得 到 
的 ) 。 这 里 的 “1011” 的 反 码 〈 也 就 是 按 位 取 反 ) 为 “0100”， 再 在 末 位 
加 “1 后 即 得 到 了 “0101”， 最 后 再 加 上 符号 位 “1”， 所 以 最 后 的 值 为 


1.0101 (符号 位 是 最 高 位 ) 。 


又 例如 ，X=+1010 时 ， 则 [X] 裤 =01010 〈 正 数 的 补 码 与 原 码 、 反 码 
一 样 ， 注 意 在 最 高 位 要 体现 数 的 正 、 负 符号 ) 。 而 当 X=-1010 时 ， 则 
[X] 补 =10110。 运 算 方法 一 样 : 先 计算 “1010” 的 反 码 ， 为 “0101”， 然 后 
再 在 未 位 加 “1”， 得 到 “0110”， 最 后 再 加 上 符号 位 *1”， 即 得 
到 “10110”。 


经 验 之 谈 整数 “0” 的 补 码 只 有 一 种 表示 形式 ， 即 00...0， 
为 “-0” 的 补 码 最 终结 果 也 是 “0”， 如 字 长 为 8 时 ，-0 的 原 码 就 为 
10000000， 求 其 补 码 时 ， 首 先是 在 原 码 中 除 符合 位 外 的 其 他 位 取 反 
(得 到 1 1111111) ， 然 后 在 最 后 位 加 1， 得 到 10 0000000， 注 意 这 里 一 
共有 9 位 了 。 因 为 字 长 为 8 位 ， 所 以 9 位 的 1 会 溢出 ， 这 样 最 后 得 到 的 补 
码 值 同 样 为 “00000000”， 也 束 是 0。 如 果 采 用 16 位 字 长 ,“-0? 的 补 码 同 
样 为 "00000000 00000000”， 因 为 这 将 产生 值 为 “1 的 第 17 位 ， 而 这 个 第 
17 位 在 16 位 字 长 中 同样 是 次 出 的 。 


表 1-2 是 8 位 二 进 制 的 原 码 、 反 码 、 补 码 对 照 表 。 在 进行 表示 形式 转 
换 时 如 果 记 得 这 个 数 ， 有 了 时 速率 会 快 许多 。 


表 1-2 8 位 二 进 制 的 原 码 、 反 码 、 补 码 对 照 表 


- 进 制 数码 “| “对 应 的 无 符号 数 对 应 本 3 数 对 应 号 数 对 应 和 3 数 
00000000 +0 
00000001 +] 

{2 


00000010 


01111111 


01111111 27 

10000000 —128 

10000001 一 127 

10000010 一 126 
2. 补 码 的 加 法 运算 


补 码 的 加 法 运算 法 则 如 下 : 
[EX+Y] 补 =[X] 补 二 [Y] 补 


该 式 表 明 ， 两 个 有 符号 数 相 加 的 补 码 可 以 通过 先 分 别 对 两 个 数 求 
促 码 ， 然 后 相 加 得 到 。 在 采用 补 码 形 式 表 示 时 ， 进 行 加 法 运算 时 可 以 
把 符号 位 和 数值 位 一 起 进行 运算 〈 若 符号 位 有 进位 ， 则 溢出 不 管 ) ， 
结果 为 两 数 之 和 的 补 码 形式 。 


如 要 求 两 个 十 进 制 数 ，35+18 的 补 码 (假设 字 长 为 8) 。 根 据 上 面 
的 补 码 加 法 运算 法 则 可 以 得 知 ， 只 需 分 别 求 35 和 18 这 两 个 数 的 补 码 ， 
然后 相 加 即 可 。 又 因 这 两 个 数 都 是 正 数 ， 所 以 它们 的 补 码 与 原 码 一 
样 。 这 样 一 来 ， 这 道 题 实 际 上 也 束 生 求 35 和 18 这 两 个 十 进 制 数 的 原 码 


和 。35 的 原 码 为 0 0100011 (注意 最 高 位 为 符号 位 ) ，18 的 补 码 为 0 
0010010。 所 以 35+18 的 补 码 就 等 于 (0 0100011)B+(0 0010010)B= 
(00110101)B， 如 图 1-18a 所 示 。 如 果 转 换 成 十 进 制 束 等 于 53， 结 果 正 
确 。 如 果 相 加 后 有 超过 字 长 的 位 洲 出 ， 则 直接 丢弃 。 


同 理 ， 如 果 要 求 两 个 十 进 制 数 : 35+(-18) 和 的 补 码 也 是 直接 求 35 
和 -18 的 补 码 和 。35 的 补 码 与 其 原 码 一 样 ， 前 面 已 计算 出 ， 为 0 
0100011; 而 后 面 那 个 “-18” 因 为 是 负数 ， 所 以 不 能 直接 从 它 的 原 码 得 到 
补 码 。 需 要 先 求 -18 的 原 码 1 0010010， 然 后 对 其 除 符号 位 外 的 其 他 各 位 
取 反 ， 得 到 其 反 码 (为 1 1101101) ， 最 后 再 在 其 末 位 (最低 位) 加 1， 
最 终 得 到 其 补 码 为 1 1101110。 


这 样 一 来 , “35-18” 的 补 码 就 是 (00100011)B+(11101110)B， 结 果 为 
00010001， 如 图 1-18b 所 示 。 这 里 要 注意 ， 两 个 补 码 相 加 后 产生 了 第 9 位 
(为 1) 的 溢出 ， 直 接 丢 弃 ， 所 以 结果 就 是 (00010001)B。 如 果 和 转换 成 十 
进 制 的 话 就 等 于 17， 结 果 正 确 。 


0 0100011 0 0100011 
+ 00010010 + 11101110 
0 0110101 区 0 0010001 

新 产生 的 最 


a ) 高 位 ， 海 出 b ) 


图 1-18 两 个 补 码 加 法 运算 示例 
3. 补 码 的 减法 运算 
补 码 的 减法 运算 法 则 如 下 : 
[X-Y] 补 =[ 久 ] 补 +-Y] 补 


该 公式 表明 ， 求 两 个 机 器 数 的 差 值 (如 [X-Y]* ) 的 补 码 ， 可 以 通 
过 求 被 减 数 的 补 码 (如 [X]， ) 与 减 数 的 负 值 的 补 码 〈LY], ) 的 和 得 
到 。 


[-Y] 补 是 对 减 数 进行 求 负 操作 ， 求 负 的 规则 是 全 部 位 〈 含 符号 位 ) 
取 反 后 再 加 1 (实际 上 也 是 分 别 对 符号 位 和 真 值 位 进行 求 反 ， 因 为 正 数 
与 负数 的 符号 也 正好 相反 ) 。 例 如 : 已 知 [15] 补 =00001111， 则 [-15] 补 
=11110000+1=11110001 。 


现在 假设 X=+35，Y=+18， 要 求 [X-Y]x、( 字 长 为 8) 。 


先 根 据 正 数 的 补 码 与 原 码 一 样 的 规则 ， 求 得 [又 ] 补 =00100011，[Y] 
补 =00010010; 再 根据 以 上 介绍 的 补 码 求 负 操 作 规 则 ， 即 可 得 到 [-Y] 补 
=11101110; 最 后 用 [X] 补 +[-Y] 补 公式 即 可 得 到 最 终 的 [X-Y] 
=00010001， 如 图 1-19a 所 示 。 和 转换 成 十 进 制 ， 也 可 得 到 结果 17， 正 确 ， 
且 与 上 面 使 用 加 法 法 则 运算 的 结果 一 样 。 注 意 ， 这 里 相 加 的 结果 也 产 
生 了 溢出 的 第 9 位 (1) ， 直 接 丢 弃 。 


0010001 1 ] 101110] 


+ 11101110 + 11101110 
_7100010001 dl 1001011 

新 产生 的 最 新 产生 的 最 

高 位 ,溢出 a) 高 位 ,溢出 ”b) 


图 1-19 两 个 补 码 减法 运算 示例 


注意 ” 原 码 、 反 码 和 补 码 运 算 的 结果 也 是 对 应 的 表示 形式 ， 因 为 
正 数 的 原 码 、 反 码 和 和 补 码 痢 一 样 ， 所 以 当 反 码 、 补 码 的 运算 结果 为 正 
数 时 ， 反 码 和 补 码 的 结果 也 就 是 对 应 的 原 码 。 但 是 如 琳 结 果 古 负数， 
则 反 码 、 补 码 的 结果 不 等 于 原 码 ， 必 须 经 过 相应 的 操作 才能 转换 为 原 
码 。 如 负数 的 反 码 要 转换 为 原 码 必须 对 反 码 除 符号 位 外 的 其 他 位 全 许 
取 反 ; 而 负数 的 补 码 要 转换 为 原 码 必须 先 在 该 补 码 的 最 后 一 位 减 1， 然 
后 对 除 符 号 位 外 的 其 他 各 位 取 反 才能 得 到 。 


如 有 两 个 十 进 制 数 分 别 是 X=-35，Y=-18， 现 要 求 [X+Y]x 的 值 ， 
很 显然 这 个 结果 是 一 个 负数。 根据 前 面 介绍 的 加 法 法 则 得 知 ， 可 先 求 
得 [又 ] 补 和 [Y] 补 的 值 ， 然 后 再 相 加 ， 即 [X] +[Y] 补 。 根 据 本 章 前 面 介 
绍 的 知识 ， 我 们 很 快 可 以 算出 [-35] 为 1 1011101，[-18]* =11101110 。 
最 后 [-35] 补 +[-18] 补 的 运算 过 程 如 图 1-19b 所 示 ， 结 果 为 11001011。 注 意 
这 是 一 个 有 符号 位 数 ， 所 以 结果 为 -75。 这 样 看 起 来 结果 是 不 正确 的 ， 
因为 -35-18 应 该 等 于 -53。 这 时 就 要 特别 注意 了 ， 这 个 -75 是 一 个 补 码 形 


式 ， 要 看 最 终 的 结果 ， 还 得 把 它 转换 成 原 码 。 按 照 上 面 介绍 的 方法 可 
得 [-75] 补 的 原 码 为 10110101 (注意 它 也 是 一 个 有 符号 位 ， 最 高 的 1 代表 
为 负数 ) =[-53] 频 。 这 样 结果 就 正确 了 。 


4. 同 步 练习 
1) 求 [85+24] 补 、[152+35] 补 的 值 ; 


2) 求 [185-56]x、[52-135]xk 的 值 。 


第 2 革 ”计算 机 网 络 概述 


本 章 作 为 本 书 的 开篇 (除了 作为 选 学 内 容 的 第 1 章 ) ， 先 从 宏观 角 
度 对 计算 机 网 络 进 行 了 概括 性 的 介绍 ， 以 便 使 大 家 对 计算 机 网 络 有 一 
个 基本 的 了 解 。 本 章 内 容 比较 丰富 ， 这 对 于 以 前 对 计算 机 网 络 方面 的 
知识 了 解 较 少 的 朋友 来 说 非常 重要 。 相 信 你 学 完 本 章 之 后 ， 再 与 朋友 
谈论 有 关 计 算 机 网 络 方面 的 话题 时 也 可 以 对 上 几 名 了， 再 也 不 会 像 以 
前 一 样 被 “冷落 "， 让 朋友 觉得 你 完全 是 一 个 局 外 人 了 。 


本 章 主要 介绍 计算 机 网 络 的 一 些 基 础 知识 ， 包 括 计算 机 网 络 的 发 
展 历史 、 基 本 组 成 、 作 用 、 分 类 、 折 扑 结构 等 。 本 章 的 重点 是 理解 各 
种 拓扑 结构 的 主要 特性 和 优 缺 点 。 当 然 ， 本 章 只 是 概述 ， 详 细 介绍 将 


在 后 续 章节 进行 。 
2.1 计算 机 网 络 概述 


学 习 计 算 机 网 络 ， 应 从 了 解 计算 机 网 络 定义 、 计 算 机 网 络 发 展 历 
史 、 计 算 机 网 络 的 基本 组 成 和 主要 应 用 开始 。 这 些 都 是 最 基本 、 最 基 
础 的 计算 机 网 络 的 知识 ， 也 是 我 们 平时 与 朋友 经 营 聊 到 的 内 容 。 


2.1.1 计算 机 网 络 的 定义 


“计算 机 网 络 定义 ? 吏 是 “什么 是 计算 机 网 络 ”。 其 实 这 个 问题 并 不 走 
很 重要 ， 而 且 也 没有 一 个 非常 精确 的 定义 。 一 开始 只 要 我 们 知道 眼前 
所 见 到 的 那些 由 许多 计算 机 设备 通过 电线 连接 在 一 起 所 组 成 的 系统 融 
是 计算 机 网 络 欧 行 了 。 


计算 机 网 络 从 诞生 起 ， 发 展 至 今 也 仅 有 50 多 年 的 历史 了 (真正 的 
计算 机 网 络 是 从 1969 年 美国 国防 部 高 级 研究 计划 署 (ARPA) 建立 
ARPANet 开 始 的 ， 这 部 分 内 容 将 在 本 章 后 面 介 绍 ) 。 在 这 短 短 的 50 来 
年 的 时 间 里 ， 各 方面 的 计算 机 网 络 技术 的 发 展 和 普及 真 可 谓 “ 日 新 月 
异 ”， 真 的 很 难 想 象 最 早 的 几米 连接 速率 在 这 么 短 时 间 里 已 发 展 到 了 几 
十 吉 的 连接 速率 ， 增 加 了 几 千 倍 。 随 着 计算 机 网 络 技术 和 应 用 的 不 断 
发 展 ， 计 算 机 网 络 的 内 涵 也 在 不 断 发 生变 化 ， 所 以 关于 “计算 机 网 
络 ”， 至 今 仍 没有 一 个 严格 意义 上 的 权威 定义 。 


目前 通常 认为 “计算 机 网 络 ” 是 指 将 不 同 地 理 位 置 ， 具有 独立 功能 
的 多 台 计 算 机 及 网 络 设备 通过 通信 线路 (包括 传输 介质 和 网 络 设备 ) 
连接 起 来 ， 在 网 络 操 作 系统 、 网 络 管理 软件 及 网 络 通信 协议 的 共同 管 
理 和 协调 下 实现 货源 共 束 和 信息 传递 的 计算 机 系统 。 如 采 你 还 不 知道 
计算 机 网 络 为 何 物 的 话 ， 回 到 家 里 ， 或 者 到 网 吧 ， 或 者 去 你 所 在 的 公 
司 去 亲眼 看 一 下 吧 。 你 所 看 到 的 那 一 人 台 人 台 看 似 独 立 、 位 于 不 同位 置 的 
PC (个 人 计算 机 ) ， 通 过 一 些 电缆 和 一 些 盒子 状 的 设备 (如 交换 机 、 
路 由 器 ) 连接 起 来 的 就 是 一 个 计算 机 网 络 。 


简单 地 讲 ， 计 算 机 网 络 就 是 许多 独立 工作 的 计算 机 系统 通过 通信 
线路 《包括 连接 电缆 和 网 络 设备 ) 相互 连接 构成 的 计算 机 系统 集合 ， 
或 者 计算 机 系统 团体 。 而 在 这 个 计算 机 系统 集合 中 ， 可 以 实现 各 计算 
机 间 的 资源 共享 、 相 互 访问 ， 可 以 进行 各 种 需要 的 计算 机 网 络 应 用 。 
其 中 的 计算 机 可 以 是 微机 、 小 型 机 、 中 型 机 、 大 型 机 或 巨型 机 等 ， 网 
络 设 备 包 括 网 桥 、 网 关 、 交 换 机 、AP、 路 由 器 、 防 火 墙 等 。 但 仅 有 这 
些 人 硬件 是 不 可 能 组 成 计算 机 网 络 的 ， 还 必须 有 相应 的 软件 系统 文 持 ， 
这 方面 内 容 将 在 本 章 后 面 介 绍 计算 机 网 络 组 成 时 再 详 述 。 这 里 所 说 
的 “资源 共享 ”包括 : 硬件 资源 共享 、 软 件 资源 共享 、 数 据 资 源 共 享 这 
三 个 方面 。 硬 件 资源 共 译 的 最 典型 例子 束 是 我 们 最 常用 的 打印 机 共享 
(还 记得 和 其 他 电脑 使 用 一 台 打 印 机 来 打印 文件 的 情形 吗 ? 如 图 2-1 所 
示 ) 、 和 磁盘 共享 (如 网 吧 中 的 无 盘 网 络 ) 。 
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图 2-1 硬件 资源 共享 示例 


服务 器 


数据 资源 共享 的 典型 例子 就 是 数据 库 资 源 共 带 ， 各 网 络 用 户 可 以 
集中 调用 一 台数 据 库 服务 占 中 的 相关 数据 信息 ， 如 图 2-2 所 示 。 各 种 应 
用 服务 器 也 是 数据 资源 共享 的 实例 ， 如 通过 FoxMail 、OutLook 等 客户 
问 邮 件 软 件 收取 邮件 ， 你 和 你 的 好 友 天 天 玩 的 网 络 游戏 ， 或 者 你 和 你 
的 家 人 天 天 在 家 里 不 同 电脑 中 看 的 网 上 的 同一 部 电影 等 。 人 至 于 软件 资 
源 共享 的 例子 也 是 非常 多 的 ， 比 如 在 企业 内 部 网 络 中 我 们 会 在 服务 器 
上 为 所 有 员工 提供 一 些 冲 用 工具 软件 共享 ， 主 用 户 目 己 选择 安装 。 如 
条 推 到 互联 网 上 ， 则 更 直观 了 ， 我 们 从 网 上 下 载 的 各 种 软件 都 是 软件 
资源 共享 的 实例 。 


图 2-2 数据 库 资 源 共 享 示例 


2.1.2 ”计算 机 网 络 的 发 展 历史 


计算 机 网 络 发 展 至 今 已 经 历 了 几 代 变 单 ， 不 仅 计 算 机 网 络 的 内 酒 
发 生 了 巨大 的 改变 ， 计 算 机 网 络 技术 和 网 络 应 用 都 不 再 是 儿 十 年 前 第 
一 、 第 二 代 计 算 机 网 络 所 能 比拟 的 了 。 了 解 计算 机 网 络 的 整个 发 展 历 
史 ， 有 助 于 我 们 对 计算 机 网 络 技术 和 应 用 的 发 展 有 一 个 清晰 的 认识 ， 
也 有 助 于 我 们 分 清 目前 哪些 才 是 主流 应 用 的 扩 术 ， 哪 些 必 已 过 时 、 我 
们 不 用 去 学 的 技术 。 当 然 要 和 完 有 了 计算 机 ， 才 能 有 计算 机 网 络 ， 束 像 
肯定 是 和 多 有 人 ， 然 后 才 会 有 人 类 社会 一 样 。 总 体 来 说 ， 可 以 把 计算 机 
网 络 的 发 展 历程 归纳 为 以 下 几 个 阶段 。 


(1) 第 一 代 计 算 机 网 络 (面向 终端 的 计算 机 网 络 ) 


1946 年 ， 世 界 上 第 一 台数 字 计 算 机 问世 。 但 当时 的 计算 机 数量 非 
利 少 ， 且 非 钊 昂贵 。 由 于 当时 的 计算 机 大 都 采用 批 处 理 方式 ， 所 以 用 
户 计 算 机 首 移 要 将 程序 和 数据 打印 成 纸 带 或 卡片 ， 再 送 到 计算 中 心 去 
处 理 。1954 年 ， 出 现 了 一 种 称 为 收发 右 (Transceiver) 的 终端 ， 人 们 使 
用 这 种 终端 首次 实现 了 将 穿孔 卡片 上 的 数据 通过 电话 线路 发 送 到 远 地 
的 计算 中 心计 算 机 的 过 程 。 目 此 以 后 ， 电 传 打 字 也 可 作为 远程 终端 与 
计算 机 相连 了 ， 用 户 可 以 在 远 地 的 电 传 打字 机 上 输入 自己 的 程序 ， 而 
计算 中 心 通过 计算 机 计算 出 来 的 结果 也 可 以 传 到 远 地 的 电 传 打 字 机 上 
并 打印 出 来 。 当 时 的 这 种 简单 的 传输 系统 就 症 计算 机 网 络 的 基本 原 


型 。 当 然 ， 这 些 离 我 们 有 些 远 ， 现 在 的 我 们 不 必 人 研究 这 些 收发 器 终 端 
及 其 数据 传输 原理 。 


第 一 代 计算 机 网 络 是 以 计算 机 主机 《其 实 相当 于 我 们 现在 所 说 * 计 
算 机 服务 器 *) 为 中 心 ， 一 台 或 多 台 终 端 围绕 计算 机 主机 分 布 在 各 处 ， 
而 计算 机 主机 的 任务 是 进行 成 批 处 理 ， 用 户 终端 则 不 具备 数据 的 存储 
和 处 理 能 力 。 从 某 种 意义 上 来 说 ， 这 根本 不 能 算是 真正 的 计算 机 网 
络 ， 因 为 终端 并 不 具备 独立 工作 的 能 力 。 所 以 我 们 现在 说 ， 计 算 机 网 
络 的 诞生 通常 不 是 指 第 一 代 计 算 机 网 络 ， 而 是 从 下 面 将 要 介绍 的 第 二 
代 计 算 机 网 络 开始 算 起 的 。 这 里 所 说 的 “终端 ”是 指 由 一 台 计 算 机 外 转 
设备 组 成 的 简单 计算 机 ， 有 点 类 似 于 现在 所 说 的 “ 瘦 客 户 机 ?， 仅 包括 
CRIT 显 示 玉 、 键 盘 ， 没 有 CPU 和 硬盘 ， 所 以 没有 数据 存储 和 处 理 能 
之 所 以 网 络 中 更 多 的 是 计算 机 终端 ， 因 为 那 时 的 计算 机 非常 兄 贯 ， 太 
了 节省 成 本 ， 所 以 在 用 户 端 通常 是 使 用 那些 不 带 关 键 部 件 的 计算 机 终 


端 。 


到 了 20 世 纪 50 年 代 中 后 期 ， 通过 像 多 路 复 用 器 (MUX) 、 线 路 集 
中 器 、 前 端 控制 器 等 通信 控制 设备 ， 计 算 机 网 络 系统 可 以 将 地 理 上 分 
散 的 多 个 终端 通过 公用 电话 交换 网 络 (PSTN) 集中 连接 到 一 台 主 机 
上 ， 这 就 是 真正 意义 上 的 第 一 代 计 算 机 网 络 ， 如 图 2-3 所 示 。 


-如 
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图 2-3 第 一 代 计 算 机 网 络 示例 


第 一 代 计 算 机 网 络 的 典型 应 用 是 当时 的 美国 航空 公司 与 BM 公司 
在 20 世 纪 50 年 代 初 开始 联合 研究 ， 并 于 20 世 纪 60 年 代 投 入 使 用 的 飞机 
订 票 系统 SABRE-I。 它 由 一 台 计 算 机 和 全 美国 范围 内 2000 个 终端 组 
成 o 


由 于 第 一 代 计 算 机 网 络 是 以 单个 计算 机 万 中 心 的 远程 联机 系统 ， 
所 以 很 显然 它 具 有 天 生 的 一 些 缺 点 ， 主 要 表现 在 如 下 两 个 方面 : 


口 担当 计算 中 心 的 计算 机 负 谷 很 重 ， 造 成 对 终端 系统 的 啊 应 比较 
慢 ， 甚 至 会 出 现 服务 器 般 涡 现象 


口 单 主机 系统 的 可 靠 性 较 低 ， 一 旦 发 生计 算 机 主机 = 瘫痪 ， 将 导致 
整个 计算 机 网 络 系 统 竣 痪 。 这 与 现在 的 C/S (服务 器 /客户 机 ) 管理 模式 
类 似 ， 但 现在 计算 机 网 络 中 服务 右 系 统 通 前 是 有 容错 配置 的 ， 那 时 的 
主机 可 没 这 种 功能 。 而 且 现 在 的 计算 机 服务 器 和 客户 机 性 能 都 非常 强 
大 ， 远 不 是 当时 的 计算 机 主机 和 终端 系统 所 能 相提并论 的 。 


(2) 第 二 代 计 算 机 网 络 (分 组 交换 式 的 计算 机 网 络 ) 


为 了 克服 第 一 代 计 算 机 网 络 的 缺点 ， 提 高 网 络 的 可 用 性 和 可 靠 
性 ， 专 家 们 又 开始 研究 将 多 台 计 算 机 互 连 的 方法 。 有 问题 就 要 想 办 人 解 
决 ， 这 与 现在 所 有 技术 的 改进 思路 是 一 样 的 。 首 先 ，1964 年 8 月 巴 兰 
(Baran) 在 美国 兰 德 (Rand) 公司 《 论 分 布 式 通信 》 的 人 研究 报告 中 提 
到 了 “存储 转发 ”( 这 在 我 们 学 习 交换 机 技术 时 会 介绍 这 项 技术 ) 的 概 
念 。 在 1962 年 至 1965 年 间 ， 美 国 的 ARPA (Advanced Research Projects 
Agency， 美 国 国防 部 高 级 研究 计划 署 ) 和 英国 的 NPL (National Physics 
Laboratory， 国 家 物理 实验 室 ) 都 对 这 一 新 技术 进行 了 人 研究。 后 来 ， 英 
国 NPL 的 戴 维 斯 (David) 于 1966 年 首次 提出 了 “分 组 ”(packet) 的 概 
念 。 在 1969 年 12 月 ， 产 生 了 世界 上 第 一 个 基于 分 组 技术 的 计算 机 分 组 
交换 系统 APPANET。 这 是 大 家 公认 的 计算 机 网 络 的 盟 祖 。 


APPANET 是 美国 国防 部 高 级 研究 计划 局 (DARPA) 采用 电话 线路 
为 主干 网 络 建成 的 。 它 最 开始 仅 连 接 了 美国 加 州 大 学 洛杉矶 分 校 、 加 
州 大 学 圣 巴 巴 拉 分 校 、 斯 坦 福 大 学 和 犹他 大 学 四 个 结 点 的 计算 机 ;两 
年 后 建成 15 个 结 点 ， 此 后 规模 不 断 扩 大 。 到 了 20 世 纪 70 年 代 后 期 ， 网 
络 结 点 超过 60 个 ， 主 机 100 多 台 ， 地 理 范 围 跨 越美 洲 大 陆 ， 连 通 了 美国 
东部 和 西部 的 许多 大 学 和 研究 机 构 ， 而 且 还 通过 通信 卫星 与 夏威夷 和 
欧洲 地 区 的 计算 机 网 络 相互 连通 。 


APPANET 的 运行 成 功 使 计算 机 网 络 的 概念 发 生 了 根本 性 的 变化 ， 
也 标志 着 计算 机 网 络 的 发 展 进 入 了 一 个 新 的 纪元 。 这 种 在 计算 机 网 络 
中 运行 各 种 应 用 程序 的 计算 机 称 为 主机 (不 再 使 用 功能 简单 的 终端 
了 ) ， 这 些 主机 提供 资源 共享 ， 组 成 “资源 子 网 ” 各 计算 机 之 间 不 是 
直接 用 线路 相连 ， 而 是 由 接口 报 文 处 理 机 (Interface Message 
Processor，IMP) 转 接 后 互 连 。IMP 专 门 负责 通信 处 理 ， 通 信 线 路 将 各 
IMP 相 互 连 接 起 来 ， 然 后 各 主机 再 与 IMP 相 连 ， 各 主机 之 间 的 通信 需要 
通过 IMP 连 接 起 来 的 网 络 来 实现 。IMP 和 它们 之 间 互 连 的 通信 线路 一 起 
负责 主机 间 的 通信 任务 ， 构 成 “通信 子 网 ?>， 如 图 2-4 所 示 。 


图 2-4 第 二 代 计 算 机 网 络 


第 二 代 计 算 机 网 络 中 的 终 问 用 户 不 仅 可 以 共 至 “通信 子 网 ”中 的 线 
路 和 设备 资源 ， 还 可 以 共享 用 户 “ 资 源 子 网 ”的 丰富 硬件 和 软件 资源 。 
这 种 以 “通信 子 网 ”为 中 心 的 计算 机 网 络 整 成 了 我 们 现在 所 说 的 第 二 代 
计算 机 网 络 。 


在 第 二 代 计 算 机 网 络 中 ， 采 用 了 “存储 -转发 ”数据 通信 方式 ， 也 下 
是 各 个 IMP 在 接收 到 数据 后 移 按 接收 顺序 把 数据 存储 在 自己 的 缓存 中 ， 
然后 再 按 接收 顺序 依次 进行 下 一 级 的 数据 转发 ， 这 样 可 以 使 网 络 上 的 
流量 更 加 平 消 、 有 序 。 如 果菜 台 主 机 的 一 个 用 户 要 发 送 数 据 给 网 络 中 
的 另 一 台 主 机 ， 它 先是 将 数据 交 给 与 其 相连 接 的 IMP， 接 着 该 IMP 通 过 
适当 的 通信 线路 转 给 下 一 个 IMP， 然 后 继续 转发 这 个 数据 ， 以 此 类 推 ， 
直到 人 到达 目的 IMP， 最 后 由 目的 IMP 转 发 给 目的 主机 。 


第 二 代 计 算 机 网 络 的 这 种 既 分 散 〈 从 地 理 位 置 上 来 讲 ) 又 统一 
(从 服务 功能 上 来 讲 ) 的 多 主机 计算 机 网 络 ， 使 得 整个 计算 机 网 络 系 
统 性 能 大 大 提高 ， 同 时 也 不 会 因为 单机 故障 而 导致 整个 网 络 系统 次 
痪 。 另 外 ， 可 以 使 原来 第 一 代 计 算 机 网 络 中 的 单一 计算 机 主机 的 负载 
可 以 分 散 到 整个 计算 机 网 络 的 各 个 计算 机 主机 上 ， 使 得 计算 机 网 络 系 
统 的 啊 应 性 能 也 大 大 提高 了 。 


(3) 第 三 代 计 算 机 网 络 (标准 化 的 计算 机 网 络 ) 


第 二 代 计 算 机 网 络 的 传输 方式 采用 了 “存储 -转发 "方式 ， 极 大 地 提 
高 了 昂贵 的 通信 线路 资源 的 利用 率 。 因 为 在 这 种 “存储 -转发 方式 的 通 
言 过 程 中 ， 通 信 线 路 不 会 被 某 一 忆 点 间 的 通信 所 独占 ， 而 是 可 以 为 多 
路 通信 所 共用 。 但 是 第 二 代 计 算 机 网 络 仍 存在 许多 沦 亲 ， 主 要 表现 为 
没有 统一 的 网 络 体系 架构 和 协议 标准 。 而 且 ， 尽 管 第 二 代 计 算 机 网 络 
已 进行 了 通信 子 网 和 资源 子 网 的 两 级 分 层 ， 但 不 同 公司 的 网 络 体系 都 
只 适用 于 目 己 公司 的 设备 ， 不 能 进行 相互 连接 。 如 IBM 于 1974 年 推出 
了 系统 网 络 结构 (System Network Architecture，SNA) ， 为 用 户 提 供 
能 够 互 连 的 成 套 通信 产品 ，1975 年 DEC 公 司 宣布 了 自己 的 数字 网 络 体 
系 结构 (DigitaoNetwork Architecture，DNA) ; 1976 年 UNIVAC 宣 布 了 
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自己 的 分 布 式 通 信 体 系 结构 (Distributed Communication Architecture， 
DCA) 。 这 些 网 络 技术 标准 只 在 一 个 公司 范围 内 有 效 ， 遵 从 某 种 标准 
的 、 能 够 互 连 的 网 络 通信 产品 ， 只 适用 于 同一 公司 生产 的 设备 ， 不 同 
公司 间 的 网 络 仍 不 能 相互 连通 。 计 算 机 网 络 通信 市 场 这 种 各 自 为 政 的 
状况 使 得 用 户 在 投资 方向 上 无 所 适 从 ， 也 不 利于 多 厂商 之 间 的 公平 竞 
第 。 


针对 上 述 情 况 ，1977 年 ISO (国际 标准 化 组 织 ) 的 TC97 信 息 处 理 
系统 技术 委员 会 SC16 分 技术 委员 会 开始 着 手 制定 开放 系统 互 连 参 考 模 
型 (OSVRM) ， 并 于 1984 年 发 布 。OSIRM 模 型 是 一 个 开放 体系 结 
构 ， 定 义 了 网 络 互 连 的 七 层 结 构 ， 并 详细 规定 了 每 一 层 的 功能 (如 图 2- 
5 所 示 ) ， 以 实现 开放 系统 环境 中 的 互 连 性 、 互 操作 性 和 应 用 的 可 移植 


性 。OSIRM 模 型 同时 规定 了 计算 机 之 间 只 能 在 对 应 层 之 间 进 行 通信 ， 
大 大 简化 了 网 络 通信 和 原理， 是 公认 的 新 一 代 计 算 机 网 络 体系 结构 的 基 
础 ， 为 普及 计算 机 网 络 黄 定 了 基础 。 


与 用 户 应 用 进程 的 接口 
进行 数据 格式 转换 

会 话 管理 和 数据 同步 

| 瑞 到 湛 表 明 地 传 给 报 广 

分 组 传输 和 路 由 选择 

在 链 路 上 无 差错 地 传输 一 帧 一 帧 的 信息 


将 比特 流放 到 物理 介质 上 传送 


图 2-5 ”OSLRM 的 七 层 结 构 及 各 层 对 应 的 基本 功能 


从 前 面 第 一 代 、 第 二 代 计 算 机 网 络 技术 的 发 展 可 以 看 出 ， 它 们 都 
古 企 业 有 驱 动 的 ， 也 就 是 由 各 个 公司 根据 自己 的 市 场 和 用 户 需 求 进行 相 
关 技 术 和 产品 开发 的 ， 可 以 说 是 处 于 “百家争鸣 ”的 时 代 。 虽 说 “ 百 家 和 争 
哆 ?可 以 充分 展示 各 家 公司 的 优势 ， 但 毕竟 “无 规矩 难 成 方圆 ”。 由 于 这 
些 公 司 间 彼 此 的 市 场 竞 争 关 系 ， 导 致 这 些 不 同 公 司 开发 出 来 的 技术 和 


产品 并 不 具有 通用 性 ， 这 样 一 来 结 采 了 束 是 谁 都 做 不 大 、 做 不 强 ， 用 户 
也 很 难 选 择 ， 计 算 机 网 络 的 发 展 也 吏 很 难 真正 有 实质 性 的 进展 。 


到 了 第 三 代 计 算 机 网 络 时 代 ， 随 着 OSVRM 的 道生， 就 把 整个 计算 
机 网 络 体系 架构 以 标准 形式 确定 下 来 了 ， 大 大 推动 了 计算 机 网 络 的 发 
展 ， 激 发 了 无 数 公 司 参与 开发 计算 机 网 络 相 关 硬 件 和 软件 ， 迎 来 了 计 
算 机 网 络 发 展 历 史上 第 一 个 真正 意义 上 的 “春天 ”。 因 为 大 家 已 * 有 规 可 
循 ” 了 ， 不 再 担心 兼容 问题 了 。 当 然 OSUVRM 标 准 的 诞生 也 二 在 汇总 了 
前 面 不 同 公司 开发 的 体系 架构 优点 的 基础 上 开发 的 。 


OSVRM 的 诞生 也 标志 着 第 三 代 计算 机 网 络 的 诞生 。 此 时 的 计算 机 
网 络 在 共同 遵循 OSI 标准 的 基础 上 ， 形 成 了 一 个 具有 统一 计算 机 网 络 体 
系 结构 ， 并 遵循 国际 标准 的 开放 式 和 标准 化 的 网 络 。1980 年 2 月 ，IEEE 
学 会 下 属 的 802 局 域 网 标准 委员 会 宣告 成 立 ， 并 相继 推出 了 和 若干 个 802 
局 域 网 协议 标准 ， 其 中 绝 大 部 分 后 来 被 OSI 正式 认可 ， 并 成 为 局 域 网 的 
国际 标准 。 这 标志 着 局 域 网 协议 及 标准 化 工作 向 前 迈 出 了 一 大 步 。 从 
1980 年 至 今 ，802 委 员 会 已 陆续 发 布 了 环 网 、 总 线 网 、 令 牌 总 线 网 、 光 
纤 网 、 宽 带 网 、 城 域 网 和 无 线 局 域 网 等 许多 局 域 网 标准 。 


这 些 IEEE 802 局 域 网 标准 的 制定 ， 极 大 地 推进 了 计算 机 局 域 网 的 
发 展 。 近 几 年 ， 计 算 机 局 域 网 的 发 展 速度 更 是 惊人 ， 王 兆 、 万 兆 、 十 
万 兆 的 局 域 网 技术 也 已 走 入 应 用 ， 百 万 焰 的 局 域 网 技术 的 人 研究 也 取得 
了 非常 不 错 的 进展 。 不 仅 如 此 ， 以 太 网 的 传输 距离 已 从 原来 局 域 网 的 


苑 围 延伸 到 了 城 域 网 、 广 域 网 的 范围 。 正 因 如 此 ， 现 在 的 局 域 网 和 广 
域 网 之 间 的 界限 变 得 越 来 越 模糊 了 。 事 实 上 ， 现 在 ， 几 乎 每 个 单位 的 
计算 机 网 络 都 授 入 了 Internet， 每 个 人 的 计算 机 也 都 已 接 入 了 Intemet， 
成 为 了 Internet 的 一 分 子 。 


最 后 ， 不 得 不 说 的 是 ， 虽 然 OSURM 的 诞生 大 大 促进 了 计算 机 网 络 
的 发 展 ， 但 主要 还 是 表现 在 局 域 网 范围 中 ， 在 后 来 的 广域网 ， 包 括 
Internet (互联 网 ) 的 发 展 中 ，OSIURM 却 被 后 来 居 上 的 TCP/IP 协 议 规 范 
(由 DARPA 研 究 并 发 布 ) 远 远 抛 在 后 面 。1983 年 ，DARPA 将 
ARPANET 上 的 所 有 计算 机 结构 转 同 了 TCP/IP 协 议 ， 并 以 ARPANET 为 
主干 建立 和 发 展 了 Intemet， 形 成 了 TCP/IP 体 系 结构 。 


TCP/IP 协 议 体系 结构 虽然 不 是 国际 标准 ， 但 它 的 发 展 和 应 用 都 远 
远 超 过 了 OSIRM， 成 为 了 Internet 体 系 结构 上 的 实际 标准 。 究 其 原因 主 
要 有 以 下 三 个 方面 : 一 是 TCPAP 协 议 复 非常 庞大 ， 功 能 完善 且 实 用 
(目前 的 Internet 基 本 上 全 是 TCP/IP 协 议 类 型 的 网 络 ) ， 用 户 基 础 好 ; 
二 是 曾经 的 Internet 的 投资 者 不 会 轻易 放弃 在 TCP/IP 协 议 体系 上 的 巨大 
投资 ， 三 是 OSVRM 的 网 络 体系 结构 本 身分 层 过 多 ， 有 些 层次 (如 会 话 
层 和 表示 层 ) 没有 太 大 单独 划分 的 必要 性 ， 而 有 些 功能 (如 流量 控制 
和 差错 控制 等 ) 又 在 多 个 层次 中 出 现 ， 实 现 和 协调 起 来 比较 难 。 


当然 ， 我 们 不 能 否认 OSIR/RM 的 页 献 ， 它 提出 了 许多 计算 机 网 络 
的 概念 和 技术 至 今 仍 广 为 使 用 ， 包 括 在 Intermmet 上 。 男 外 ， 也 正 古 在 它 


的 推动 下 ， 使 得 计算 机 网 络 体系 结构 的 标准 化 工作 不 断 进 展 ， 事 实 上 
后 来 的 TCP/IP 协 议 规范 也 是 在 OSVRM 基 础 上 改进 而 来 的 。 


说 明 有 关 计 算 机 网 络 体系 结构 方面 的 具体 内 容 将 在 第 3 章 具 体 介 
绍 ， 有 关 这 些 计算 机 网 络 体系 结构 中 各 层 的 主要 功能 和 技术 实现 原理 


将 在 后 续 各 章 中 分 别 介绍 。 


(4) 第 四 代 计算 机 网 络 (国际 化 的 计算 机 网 络 ) 


到 了 20 世 纪 80 年 代 末 ， 局 域 网 拉 术 发 展 成 熟 ， 出 现 了 光纤 及 高 速 
以 太 网 技术 ， 局 域 网 的 组 建 和 应 用 也 首先 在 国外 ， 特 别 是 美国 开始 普 
及 开 来 。 随 着 第 三 代 计 算 机 网 络 中 的 OSLRM 体 系 架构 的 诞生 ， 又 大 大 
促进 了 以 Internet 为 代表 的 因特网 的 发 展 ， 这 就 是 现在 的 第 四 代 计 算 机 
网 络 。 第 四 代 计 算 机 网 络 的 定义 为 “将 多 个 具有 独立 工作 能 力 的 计算 机 
系统 通过 通信 设备 和 线路 由 功能 完善 的 网 络 软件 实现 资源 共享 和 数据 
通信 的 系统 ”。 其 实 ，Intemet 的 锥 形 就 是 DARPA 的 ARPANET， 所 采用 
的 协议 标准 就 是 TCP/IP 协 议 规范 。 


Internet 的 基本 发 展 历史 如 下 : 1985 年 美国 国家 科学 基金 会 
(National Science Foundation) 利 用 ARPANET 协 议 建 立 了 用 于 科学 研究 
和 教育 的 骨干 网 络 NSFnet;， 1990 年 NSFnet 取 代 ARPANET 成 为 国家 骨干 
网 ， 并 且 走 出 了 大 学 和 研究 机 构 进 入 社会 ， 从 此 网 上 的 电子 邮件 、 文 
件 下 载 和 信息 传输 受到 人 们 的 欢迎 和 广泛 使 用 ; ，1992 年 ，Internet 学 会 


成 立 ; 1993 年 ， 伊 利 诸 斯 大 学 国家 超级 计算 中 心 成 功 开发 出 网 上 浏 蜗 
工具 Mosaic (后 来 发 展 为 Netscape) ， 同 年 克林顿 宣布 正式 实施 国家 信 
息 基础 设施 (National Information Infrastructure) 计划 ， 从 此 在 世界 范 
围 内 开始 了 争夺 信息 化 社会 领导 权 和 制高点 的 竞争 ， 与 此 同时 NSF 不 再 
向 Internet 注 入 资金 ， 完 全 使 其 进入 商业 化 运作 ;20 世纪 90 年 代 后 期 ， 

Interner 以 惊人 的 速度 发 展 ， 一 直到 今天 。 


(5) 下 一 代 计 算 机 网 络 


有 人 会 问 ， 我 们 现在 的 计算 机 处 于 一 个 什么 时 代 ? 可 以 这 么 说 ， 
我 们 目前 正 处 于 第 四 代 和 人 第 五 代 之 间 的 过 渡 时 期 。 但 最 终 下 一 代 网 络 
到 压 是 什么 样子 ， 现 在 可 能 还 没有 人 能 全 部 说 清楚 ， 至 少 没有 形成 标 
准 。 总 体 而 言 ， 普 过 认为 下 一 代 计 算 机 网 络 \(NGN， 也 就 是 我 们 所 说 
的 第 五 代 计算 机 网 络 ) 是 因特网 、 移 动 通信 网 络 、 固 定 电话 通信 网 络 
的 融合 ，IP 网 络 和 光 网 络 的 融合 ， 是 可 以 提供 包括 语 首 、 数 据 和 多 媒 
体 等 各 种 业务 的 综合 开放 的 网 络 构 染 ， 古 业务 驱动 、 业 务 与 呼叫 控制 
分 离 、 呼 叫 与 承载 分 离 的 网 络 ， 是 基于 统一 协议 的 、 基 于 分 组 的 网 
络 。 在 功能 上 NGN 分 为 四 层 ， 即 接 入 和 传输 层 、 媒 体 层 、 控 制 层 、 网 
络 服 务 层 。 我 们 看 得 见 的 一 些 下 一 代 计 算 机 网 络 的 主要 特征 包括 : 目 
前 正在 进行 的 就 是 “三 网 ” (计算 机 网 络 、 电 信 网 络 、 广 东 电视 网 络 ) 
融合 ， 物 联网 、 虚 拟 化 、 云 计算 、HTML5 等 狐 的 结 命 性 技术 等 。 


在 这 些 狐 技术 中 ,“ 云 计算 ”和 "“ 物 联网 ?可 能 是 将 来 彻 辰 改变 目前 计 
算 机 网 络 格 局 和 应 用 的 最 主要 的 两 大 技术 。“ 云 计算 ”其 实 类 似 于 以 前 
的 BM 大 型 机 ， 是 一 种 集中 服务 、 集 中 管理 的 平台 。 束 古 由 云 计 算 运 
营 商 集中 为 企业 客户 提供 一 些 软 、 硬 件 平台 及 各 种 所 需 的 服务 和 管 
理 ， 企 业 客户 只 需要 通过 比较 简单 的 云 计 算 客 户 端 连 上 位 于 互联 网 上 
的 运营 商 云 计算 平台 就 可 享受 所 购买 的 服务 、 平 台 ， 大 大 字 省 了 企业 
客户 在 计算 机 网 络 软 、 硬 件 平 台 (如 各 种 服务 器 系统 、 企 业 交 换 机 、 
路 由 器 、 防 火 墙 等 ) 上 的 投资 。 


“ 物 联 网 ”是 一 种 继续 扩展 计算 机 网 络 的 新 型 技术 ， 简 单 地 讲 束 
是 “ 物 - 物 相 联 的 网 >。 它 是 通过 射频 识别 (RFID) 技术 ， 以 及 红外 感应 


器 、 全 球 定 位 系统 、 激 光 扫 描 融 等 信息 传 感 设 备 ， 按 约定 的 协议 ， 把 
一 些 目前 不 能 与 计算 机 网 络 连接 的 物品 (如 电灯 、 电 器 、 监 控 设 施 
等 ) 与 互联 网 连接 ， 以 便 进 行 物品 之 间 的 信息 交换 和 通信 ， 实 现 对 物 


品 的 智能 化 识别 、 定 位 、 跟 踩 、 监 控 和 管理 。 通 过 “ 物 联网 ”我们 将 来 
在 上 班 时 束 可 以 控制 家 里 的 电灯 、 电 夯 设 施 的 开关 ， 监 控 家 里 的 防盗 
监 探 设施， 真正 实现 无 处 不 在 的 互联 网 应 用 。 


2.1.3 ”计算 机 网 络 的 基本 组 成 


无 论 定 从 前 面 哪个 定义 都 可 以 看 出 ， 计 算 机 网 络 是 一 个 由 一 坚硬 
件 设 备 和 相应 的 软件 系统 组 成 的 完整 系统 。 计 算 机 网 络 的 基本 组 成 包 
括 : 计算 机 (或 者 是 只 具有 基本 计算 机 功能 的 计算 机 终端 、 网 络 连 
接 和 通信 设备 、 传 输 介质 、 网 络 通信 软件 (包括 网 络 通 信 协 议 ) 。 


以 上 这 些 计 算 机 网 络 基本 组 成 又 分 为 硬件 系统 和 软件 系统 两 大 部 
分 ， 如 图 2-6 所 示 。 


计算 机 网 络 系统 


计算 机 网 络 硬件 系统 计算 机 网 络 软件 系统 


计算 机 网 络 设 | | 传输 介 计算 机 软件 网 络 设备 软 计算 机 和 

和 终端 备 ( 裸 | | 质 ( 或 (包括 网 络 件 (包括 操 网 络 设 备 

( 裸 机 ) 机 ) 媒体 ) 操作 系统 、 作 系 统 和 网 中 的 网 络 
网 络 通信 和 络 通 信 软 件 )| | 通信 协议 
应 用 软件 ) 


图 2-6 计算 机 网 络 系统 组 成 


1. 计 算 机 网 络 硬件 系统 


计算 机 网 络 硬件 系统 就 是 指 计算 机 网 络 中 可 以 看 得 见 的 物理 设 
施 ， 包 括 各 种 计算 机 设备 、 传 输 介质 、 网 络 设备 这 三 大 部 分 。 


(1) 计算 机 设备 


组 建 计 算 机 网 络 的 目的 就 是 为 各 种 计算 机 设备 用 户 之 间 的 网 络 通 
信 〈 可 以 是 用 户 访问 、 数 据 传输 、 文 件 共 享 、 远 程控 制 等 应 用 ) 提供 
平台 。 计 算 机 设备 束 是 由 网 络 用 户 控 制 和 使 用 的 各 种 计算 机 (如 PC、 
计算 机 服务 磊 、 计 算 机 终端 、 笔 记 本 式 计算 机 、iPAD 之 类 的 便携 陈设 
备 ) 。 网 络 的 主要 应 用 都 是 在 这 些 计 算 机 设备 上 进行 的 。 其 实现 在 计 
算 机 网 络 与 电信 通信 网 络 有 些 重 合 了 ， 许 多 电信 通信 终端 同样 可 以 连 
接 到 计算 机 网 络 中 ， 如 我 们 现在 所 使 用 的 智能 手机 ， 残 可 以 通过 USB 
接口 与 计算 机 之 间 进 行 数据 传输 ， 甚 至 进行 远程 通信 。 


说 明 在 传统 的 计算 机 网 络 定义 中 ， 计 算 机 网 络 至 少 要 求 有 一 台 
功能 完整 的 物理 计算 机 (其 他 的 可 以 是 终端 。 随 着 网 络 虚拟 化 技术 
的 兴起 ， 目 前 的 计算 机 网 络 可 以 通过 虚拟 机 软件 (如 VPC、VMWare 
等 ) 在 一 台 物 理 计算 机 中 模拟 多 个 独立 计算 机 系统 ， 组 成 一 个 虚拟 的 
计算 机 网 络 ， 通 过 这 个 网 络 同样 可 以 实现 在 许多 物理 计算 机 网 络 中 才 
能 实现 的 功能 。 


(2) 网 络 设备 


在 计算 机 网 络 系统 中 ， 网 络 设备 通常 是 指 除 计 算 机 设备 以 外 的 设 
备 ， 如 有 线 网 络 中 的 网 卡 、 网 桥 、 网 关 、Modem、 交 换 机 、 路 由 器 、 
硬件 防火 墙 、 硬 件 IDS 〈 入 侵 检 测 系统 ) 、 硬 件 IPS (入 侵 防御 系 
统 ) 、 宽 带 接 入 服务 器 (BRAS) 、UPS (不 间断 电源 ， 等 ， 无 线 网 络 
(WLAN) 中 的 WLAN 网 卡 、WLAN AP、WLAN 路 由 器 、WLAN 交 换 
机 等 。 有 关 这 些 计算 机 网 络 设备 的 主要 用 途 和 特点 将 在 本 书后 面 专 门 


J 


网 络 设备 是 用 来 构建 “通信 子 网 ”中 网 络 拓 扑 结构 的 ， 与 所 用 的 通 
言 线路 (也 就 是 “传输 介质 ”) 一 起 共同 组 成 整个 计算 机 网 络 的 骨架 。 
当然 最 简单 的 网 络 ， 其 实 是 不 需 任何 网 络 设备 的 ， 那 就是 两 台 终端 计 
算 机 用 串 / 并 口 电 统 直 接连 接 起 来 的 对 等 网 络 。 但 这 种 网 络 其 实 并 不 能 
算是 真正 意义 上 的 计算 机 网 络 ， 对 于 现在 来 说 ， 这 样 的 计算 机 网 络 也 
没 多 大 的 实际 意义 。 


(3) 传输 介质 


传输 介质 简单 地 说 就 古 网 线 ， 是 网 络 通 信 的 “路 ”。 如 来 没有 这 些 
传输 介质 ， 网 络 通信 信号 将 不 知道 往 哪 里 传 ， 也 不 可 能 传 ， 束 像 前 面 
没有 路 ， 我 们 无 法 向 前 行进 一 样 。 当 然 ， 传 输 介质 可 以 古物 理 有 形 
的 ， 如 同 轴 电 缆 《有 线 电视 所 用 的 电缆 也 是 同 轴 电 缆 ) 、 双 绞 线 、 光 
缆 〈 也 常 叫 光 纤 ) 等 (依次 如 图 2-7 的 a、b、c 所 示 ) ; 还 可 以 是 无 形 
的 ， 如 各 种 无 线 网 络 中 使 用 的 传输 介质 其 实 吏 生 电磁 波 。 无 线 计算 机 


网 络 就 是 通过 电磁 波 实 现 无 线 计 算 机 网 络 中 各 节点 连接 的 。 当 然 ， 在 
同 轴 电 绕 、 双 绞 线 、 光 绕 这 些 传输 介质 中 又 有 许多 分 类 ， 具 体 将 在 第 4 
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图 2-7 同 轴 电 缆 、 双 绞 线 、 光 绕 
2. 计 算 机 网 络 软件 系统 


计算 机 网 络 通信 除了 需要 前 面 所 说 的 各 种 计算 机 硬件 系统 外 ， 还 
需要 一 些 计 算 机 网 络 通 信和 应 用 软件 。 这 些 计算 机 网 络 通信 和 应 用 软 
件 就 是 指 安装 在 终端 计算 机 中 ， 用 于 计算 机 网 络 通信 或 应 用 的 计算 机 
程序 。 首 先 要 有 的 就 是 一 个 网 络 应 用 平台 ， 如 计算 机 和 服务 器 上 所 安 
装 的 、 具 备 计 算 机 网 络 通信 功能 的 操作 系统 。 像 交换 机 、 路 由 器 和 防 
火 墙 等 ， 这 类 设备 上 也 会 安装 用 于 计算 机 网 络 通信 的 操作 系统 。 如 计 
算 机 或 服务 器 上 所 安装 的 各 种 Windows 系 统 、Linux 系 统 、UNIX 系 统 ， 


Cisco 交 换 机 /路 由 器 /防火 墙 上 安装 的 CatOS、IOS 系 统 ，H3C 交 换 机 /路 
由 器 /防火 墙 上 安装 的 Comware 系 统 等 。 


除了 操作 系统 以 外 ， 还 需要 独立 或 者 内 植 于 操作 系统 中 的 网 络 通 
信 协 议 ， 如 TCP/IP 协 议 艇 、IEEE 802 协 议 复 、PPP、PPPoE、IPX/SPX 
等 ， 及 网 络 设 备 中 的 VLAN、STP、RIP、OSPF、BGP 等 。 最 后 就 是 需 
要 进行 各 种 具体 网 络 应 用 的 工具 软件 ， 如 我 们 常见 的 QQ、MSN 等 即时 
通信 和 软件，Outlook、Firefox、Sendmail 等 电子 邮件 软件 ， 用 于 拨号 的 
PPP、PPPoE 协 议 ， 用 于 VPN 通 信 的 IPSec、PPTP、L2TP 协 议 等 。 


说 明 ”有关 网 络 设备 中 的 各 种 通信 协议 的 具体 工作 原理 和 应 用 配 
置 ， 可 参见 笔者 编著 的 《Cisco 交 换 机 配置 与 管理 完全 手册 》、《H3C 
交换 机 配置 与 管理 完全 手册 》、《Cisco 路 由 器 配置 与 管理 完全 手册 》 
和 《H3C 路 由 器 配置 与 管理 完全 手册 》 这 四 本 专著 (这 四 本 图 书 将 于 
2013 年 6 月 份 前 出 版 上 市 ) 。 


2.1.4 计算 机 网 络 的 主要 应 用 


说 到 计算 机 网 络 ， 大 家 肯定 首先 要 问 的 是 它 到 展 有 什么 用 途 ， 也 
就 是 我 们 可 以 用 它 来 做 什么 。 如 果 时 光 倒 退 十 多 年 ， 问 到 计算 机 网 络 
有 什么 用 途 时 ， 可 能 大 家 会 不 约 而 同 地 回答 为 “资源 共享 ”。 那 时 的 计 
算 机 网 络 应 用 的 确 如 此 ， 除 了 主要 用 于 资源 共享 外 ， 看 不 出 有 其 他 方 
面 的 应 用 ， 因 为 那 时 既 没 有 互联 网 ， 又 没有 什么 局 域 网 内 部 的 网 络 应 
用 。 现 在 ， 随 着 计算 机 网 络 系统 ， 特 别 是 Internet 撤 术 的 完善 与 普及 ， 
计算 机 网 络 的 应 用 得 到 了 空前 繁 采 。 已 渗透 到 了 普通 百姓 的 日 常 工 
作 、 生 活 和 休闲 等 各 个 方面 。 可 以 说 ， 我 们 现在 是 生活 在 网 络 时 代 ， 
天 于 计算 机 网 络 的 用 途 ， 绝 大 多 数 普通 计算 机 网 络 用 户 都 可 以 说 出 个 
i 


虽然 目前 的 计算 机 网 络 应 用 非常 多 ， 但 总 体 上 可 以 分 为 两 大 类 : 
商业 应 用 、 家 庭 / 个 人 应 用 。 下 面 进行 具体 介绍 ， 大 家 可 以 对 照 地 看 一 
下 目 己 公司 ， 力 至 本 人 用 到 了 哪些 。 


1. 商 业 应 用 


商业 应 用 是 计算 机 网 络 应 用 的 最 主要 的 方面 ， 后 面 的 家 性 /个 人 应 
用 是 在 商业 应 用 基础 上 发 展 而 来 的 。 在 计算 机 网 络 的 商业 应 用 中 ， 主 
要 依赖 的 网 络 整 是 公司 局 域 网 ， 以 及 与 公司 局 域 网 连接 的 外 部 用 户 


(如 子 公司 、 合 作 伙伴 、 供 应 商 等 ) 的 内 部 局 域 网 和 Internet。 商业 应 
用 主要 包括 : 资源 共 圣 、 数 据 传输 、 协 同 工 作 、 远 程 访问 与 管理 、 电 
子 商 务 等 。 


在 计算 机 网 络 中 ， 一 个 最 基本 ， 也 是 最 传统 的 应 用 就 古 资 源 共 至 
(Resource Sharing) 。 这 里 的 共享 资源 可 以 是 物理 设备 ， 如 打印 机 、 
扫 揪 仪 、 传 真 机 、 刻 隶 机， 也 可 以 是 共 至 的 数据 文件 、 软 件 资 源 等 。 
其 目标 整 古 让 每 个 人 都 可 以 访问 其 允许 的 设备 、 程 序 、 文 件 和 数据 信 
恩 。 一 个 最 简单 的 资源 共 译 的 例子 束 是 局 域 网 内 部 多 用 户 通 过 网 络 共 
享 一 台 打 印 机 (现在 有 些 打印 机 也 支持 Intermet 共 享 打印 ) 进行 打印 操 
作 ， 这 样 一 来 ， 公 司 吏 没 有 必要 为 每 个 用 户 配备 一 全 单独 的 打印 机 
了 大 大 节 管 了 设备 投 价 成本。 


在 公司 局 域 网 中 ， 比 物理 设备 共 译 意义 更 重要 的 还 十 我 们 前 面 提 
到 的 程序 、 文 件 和 数据 资源 共 诗 ， 如 公司 内 部 公用 文档 、 数 据 库 报 
表 ， 或 者 用 户 共 至 安装 使 用 的 软件 ， 以 及 公司 数据 库 系 统 。 局 域 网 的 
好 处 吏 是 我 们 无 需 再 像 没 有 计算 机 网 络 时 那样 ， 需 要 通过 移动 媒体 
(如 软盘 、U 盘 、 移 动 硬 副 等 ;来 复制 数据 了 。 这 样 既 确 保 了 共享 交 
据 的 安全 性 《因为 共享 时 还 可 以 为 不 同 用 户 设置 不 同 的 访问 权限 ) ， 
又 大 大 提高 了 数据 共 译 使 用 的 效率 。 通 常 在 公司 内 部 局 域 网 中 ， 会 有 
一 个 文件 服务 器 来 存储 这 些 共 吾 数 据 资 源 。 


在 互联 网 中 的 货源 共享 实例 就 更 多 了 ， 如 许多 网 站 提供 的 文件 上 
传 和 下 载 功能 ， 首 、 视 频 分 至 功能 ， 文 件 浏览 和 查阅 功能 等 。 


(2) 网 络 通信 


在 网 络 通信 方面 ， 目 前 在 企业 中 用 得 较 多 的 功能 是 远程 网 络 互 
联 、 远程 视频 会 议 ， 远 程 塔 训 、 远 程 会 诊 等 。 远 程 网 络 互联 目前 在 集 
团 公司 与 子 公 司 之 间 ， 或 者 公司 与 合作 伙伴 、 供 应 两 网 站 之 间 通 过 专 
门 的 接 入 方式 (目前 主要 是 利用 VPN 技 术 ) 把 各 单位 的 网 络 按照 应 用 
需求 和 访问 权限 连接 起 来 。 这 样 可 以 使 网 络 间 的 通信 、 用 户 访问 更 加 
安 人 全、 便利， 还 可 以 更 有 效 地 管理 网 站 数据 、 电 子 商务 数据 等 。 


远程 视频 会 议 、 远 程 培训 、 远 程 会 诊 等 的 应 用 目前 在 一 些 大 的 集 
团 公司 或 医院 中 是 很 常见 的 。 应 用 这 个 功能 一 方面 可 以 市 省 会 议 、 培 
训 成 本 (因为 它 克 服 了 物理 距离 的 时 空 限制 ，， 男 一 方面 可 以 充分 利 
用 各 方面 的 专家 资源 ， 及 时 地 解决 一 些 疑 难 杂 症 。 


(3) 数据 传输 


在 计算 机 网 络 中 进行 数据 传输 是 最 常见 的 了 ， 如 我 们 天 天 在 用 E- 
mail 邮 件 收发 、 通 过 FTP (文件 传输 协议 ， 进行 文件 传输 、 通 过 
TFTP/RCP 〈 简 单 文件 传输 协议 /远程 复制 协议 ) 进行 文件 上 传 和 下 载 
等 。 叉 如 我 们 可 能 天 天 都 在 通过 QQ 或 者 MSN 等 工具 软件 问好 友 发 送 
文件 ;许多 网 站 提供 了 资源 下 载 功能 ， 供 用 户 根据 需要 选择 下 载 他 们 


资源 库 中 的 文件 ， 现 在 义 有 了 一 些 专门 用 于 资源 上 传 和 下 载 的 网 站 网 
盘 等 。 这 些 上 传 和 下 载 的 过 程 都 属于 计算 机 网 络 的 数据 传输 应 用 。 


(4) 协同 工作 


协同 工作 是 目前 计算 机 网 络 的 一 种 典型 应 用 ， 是 指 通 过 网 络 ， 使 
位 于 相同 或 者 不 同 地 后， 甚至 不 同 国家 的 多 个 系统 共同 担负 着 茶 项 网 
络 通 信 或 者 网 络 应 用 任务 的 工作 方式 。 最 典型 的 例子 如 服务 器、 交换 
机 集群 实现 的 负载 均衡 ，ISP 中 的 多 个 DNS 服务 器 、DC ( 域 控 制 器 ) 
服务 钴 等 也 可 以 实现 负载 均衡 ， 为 网 络 用 户 提供 相应 的 服务 。 


协同 工作 目前 还 有 一 个 应 用 就 是 现在 的 维基 (Wiki) 百科 ， 其 中 
的 内 容 可 以 由 全 球 授 权 参 与 的 网 友 共 同 编辑 、 完 善 。 还 有 ， 如 一 个 项 
目 可 以 由 总 公司 和 分 公司 的 多 人 共同 负责 完成 


(5) 远程 访问 与 管理 


远程 访问 与 管理 是 计算 机 网 络 用 户 访问 ， 以 及 管理 员 对 客户 机 和 
服务 硕 的 管理 方式 。 如 一 些 文 持 移动 上 网 的 VPN 解 决 方案 殉 可 以 使 公 
司 员工 在 任何 时 候 、 任 何 地 点 通过 VPN 连 接 到 公司 的 网 络 ， 碍 看 所 需 
的 文件 或 数据 ， 上 传 或 下 载 所 需 的 文件 。 男 外 ， 利 用 像 Windows 服 务 
妖 系 统 中 的 “远程 Web 吕 面 " 和 “远程 协助 ”功能 忠 可 以 使 在 外 出 差 的 员 
工 通 过 Internet 访 问 其 至 控制 公司 内 部 网 络 中 的 主机 或 服务 器 。 如 采 具 
有 管理 员 账户 ， 他 们 还 可 以 远程 管理 、 维 护 公 司 内 部 的 服务 器 。 


(6) 电子 商务 


现在 儿 乎 所 有 稍 具 规模 的 单位 都 架设 了 目 己 的 网 站 ， 目 的 之 一 束 
征 回 全 世界 的 用 户 宣传 目 己 的 产品 。 另 外 还 有 大 部 分 企业 用 户 通过 目 
己 的 网 站 为 客户 提供 网 上 在 线 交 易 ， 这 束 是 我 们 通 利 所 说 的 “电子 商 
务 *”。 相 信 大 多 数 人 都 有 过 在 淘宝 网 购物 的 体验 ， 淘 宝 网 上 有 许多 商家 
开店 销售 他 们 的 商品 ， 这 些 商品 大 到 名 贵 珠宝 、 家 用 电器 ， 小 到 日 用 
百货 和 图 书 ， 一 应 俱全 。 还 有 像 当 当 网 、 亚 马 逊 章 越 网 、 素 东 商 城 等 
(目前 这 类 网 店 非常 多 ， 数 不 胜 数 了 ) 都 允许 各 种 商品 在 网 站 上 销 
售 。 现 在 通常 把 这 些 电 子 商务 网 站 称 为 " 电 商 ”， 以 区 别 于 实体 开店 的 
i 


“电子 商务 ”这 种 经 则 模式 最 大 的 优点 有 三 个 : 一 是 受众 面 广 ， 全 
国力 至 全 球 的 人 都 可 以 看 到 ， 二 是 成 本 低 ， 因 为 这 类 电子 商务 网 站 不 
需要 租用 昂贵 的 实体 店面 ， 只 需要 利用 虚拟 的 磁盘 空间 就 可 以 了 ; 三 
征用 户 购买 方便 ， 只 需要 在 网 上 提交 所 购 商 品 订单 ， 吏 可 以 坐 在 家 里 
等 着 收 货 了 ， 而 不 用 杀 目 跑 到 商店 中 去 买 ， 然 后 还 要 想 办 法 运 回 来 。 


2. 家 庭 应 用 


一 开始 ， 计 算 机 网 络 基本 上 全 部 是 出 于 商业 应 用 的 ， 但 随 着 
Internet 宽 市 接 入 和 互联 网 应 用 的 丰富 ， 计 算 机 网 络 开始 走 入 寻 第 百姓 
的 家 。 现 在 ， 我 们 坐 在 家 里 束 可 以 通过 家 里 的 宽带 接 入 访问 互联 网 ， 


访问 全 球 的 网 站 ; 通过 像 QQ、MSN 之 类 的 即时 通信 软件 与 世界 各 地 
的 相识 或 不 相识 的 朋友 取得 即时 联系 ， 建 立 感情 ， 我 们 还 可 以 有 目 己 
的 局 域 网 ， 或 者 个 人 网 站 ， 全 世界 的 人 都 可 以 访问 我 们 的 网 站 ， 了 解 
我 们 提供 的 产品 、 服 务 ， 以 及 我 们 的 工作 、 学 习 和 生活 状态 。 


在 娱乐 方面 ， 现 在 各 大 电视 台 都 开通 了 网 上 频道 ， 各 种 娱乐 世 目 
可 以 直接 通过 互联 网 进行 互动 参与 。 网 上 看 电影 、 昕 音乐 和 手机 上 网 
娱乐 更 是 年 青 一 族 的 时 尚 追求 〈 现 在 电信 推出 的 IPTV 已 实现 了 电影 、 
电视 、 音 乐 、 游 戏 等 各 方面 的 互动 点 播 ， 束 像 在 目 己 的 电脑 中 播放 一 
样 ) ;而 网 络 游戏 则 成 了 年 青 一 族 的 最 爱 (还 记得 你 与 朋友 们 在 网 络 
游戏 中 一 起 拼 杀 的 场景 吗 ?” ) 。 


当然 ， 现 在 的 计算 机 网 络 应 用 可 能 还 远 不 止 以 上 这 些 ， 因 为 它 已 
渗透 到 了 我 们 工作 、 和 生活、 学 习 和 娱乐 等 各 个 方面 ， 而 且 各 种 新 的 网 
络 应 用 也 在 不 断 浦 现 中 。 


2.2 ”计算 机 网 络 的 分 类 


目 计算 机 网 络 诞生 至 今 ， 出 现 过 许多 类 型 的 计算 机 网 络 ， 可 以 依 
据 许 多 不 同 的 分 类 标准 来 划分 这 些 计算 机 网 络 。 如 按 通信 协议 类 型 分 
为 IJBM 令 牌 网 络 、 分 组 交换 网 络 、 以 太 网 协议 局 域 网 、TCP/IP 协 议 网 
络 等 ; 按 管理 模式 则 可 分 为 对 等 网 和 C/S (客户 机 /服务 器 ) 网 络 ， 按 不 
同 传输 介质 则 可 分 为 同 轴 电 缴 网 络 、 双 绞 线 网 络 、 光 纤 网 络 、WLAN 
无 线 网 络 、 卫 星 网 络 、 微 波 网 络 等 ， 按 传输 方式 来 分 又 可 分 为 点 对 点 
网 络 和 广播 网 络 ， 按 所 履 盖 的 地 理 范 围 色 可 分 为 局 域 网 、 城 域 网 和 广 
域 网 ， 等 等 。 下 面 介 绍 几 种 目前 最 常见 的 计算 机 网 络 分 类 方式 。 


2.2.1 控 网 络 所 腹 协 的 地 理 泥 围 分 


按照 计算 机 网 络 覆 盖 的 地 理 范 围 (也 是 一 种 按 网 络 规 模 进 行 的 计 
算 机 网 络 分 类 ) 可 分 为 局 域 网 、 城 域 网 和 广域网 三 种 。 这 种 分 类 方式 
可 以 很 好 地 反映 出 不 同类 型 网 络 的 技术 特征 ， 因 为 不 同类 型 网 络 履 兰 
的 地 理 范 围 不 同 ， 故 所 采用 的 传输 技术 也 束 不 同 ， 从 而 形成 了 不 同 的 
网 络 技术 特点 与 网 络 服务 功能 。 


1. 局 域 网 


局 域 网 (Local Area Network，LAN) 是 最 常见 到 的 ， 也 是 应 用 最 
多 的 一 种 计算 机 了 网络， 大 到 各 行 各 业 的 企业 内 部 网 络 ， 小 到 千家 万 户 
的 家 庭 网 络 都 属于 局 域 网 〈 仅 指 内 部 网 络 部 分 | 。 我 们 党 说 的 校园 网 
通 音 也 是 一 种 局 域 网 。 局域网 是 将 一 个 比较 小 的 区 域内 的 各 种 通信 设 
备 互 连 在 一 起 组 成 的 计算 机 网 络 。LAN 具 有 如 下 主要 特点 : 


(1) 私有 服务 


LAN 属 于 个 人 或 单位 自 建 ， 所 以 其 用 途 也 是 完全 出 于 私 用 ， 不 会 
为 网 络 以 外 人 员 提 供 服务 ， 如 企业 局 域 网 通 闻 只 为 本 单位 员工 提供 服 
务 。 在 LAN 中 也 是 采用 专门 为 LAN 分 配 的 私有 了 地 址 (这 种 地 址 每 个 
公司 和 个 人 都 可 直接 拿 来 使 用 ， 无 须 购买 ， 也 无 须 注 册 ) 。 关 于 局 域 


网 的 具体 内 容 将 在 第 8 章 介绍 。 


(2) 分 布 范围 较 小 


LAN 中 各 计算 机 网 络 设备 分 布 的 地 理 范 围 较 小 ， 有 的 甚至 只 是 在 
目 己 家 里 那儿 平方 米 范围 内 ， 当 然 也 可 以 是 镑 大 艺 围 内 的 设备 相连 ， 
如 分 布 在 某 公 司 不 同 建筑 物 中 。LAN 的 地 理 分 布 范围 通常 最 大 在 10 公 
里 范围 内 ， 可 以 分 布 在 不 同 地 理 位 置 的 建筑 物 内 。 


(3) 结构 简单 ， 布 线 容易 


因为 LAN 痢 为 个 人 或 单位 私 用 ， 所 以 网 络 结构 相对 较为 商 单 。 没 
有 ， 也 无 需 太 多 、 太 复杂 的 网 络 设备 和 应 用 ， 只 需 满足 自身 的 网 络 应 
用 需求 即 可 。 同 时 大 多 数 LAN 都 采用 比较 廉价 的 双 绥 线 布线 (在 较 大 
公司 的 核心 层 或 者 汇聚 层 也 有 采用 光纤 作为 传输 介质 的 ) ， 且 因为 分 
布 范围 比较 小 ， 所 以 布线 方式 较为 简单 ， 容 易 实 现 。 


(4) 网 络 速度 较 快 


目前 以 太 网 局 域 网 技术 的 发 展 非常 迅速 ， 最 快 的 以 太 网 速率 已 达 
到 了 10Gbps， 相 对 广域网 和 互联 网 来 说 具有 非常 大 的 优势 ， 这 也 为 企 
业 局 域 网 的 集中 应 用 提供 了 保证 。 


(5) 误 码 率 低 


因为 局 域 网 的 结构 比较 简单 ， 而 网 络 连接 带宽 又 都 很 高 ， 所 以 通 
信 的 误 码 率 比 较 低 ， 通 党 在 10- 工 ~103 之 间 。 


在 LAN 中 又 有 许多 分 类 ， 如 目前 最 主流 的 以 太 网 (EtherNet) 、 
WLAN (无 线 局 域 网 ) ， 以 前 还 有 IBM 令 牌 网 (传输 速率 最 高 可 达 
16Mbps) 、FDDI (光纤 分 布 式 数 据 接口 ) 网 (最 高 传输 速率 可 达 
100Mbps) 、ATM (异步 传输 模式 ) 网 (最 高 传输 速率 可 达 Gbps 以 
上 ) 。 而 以 太 网 中 又 有 许多 分 类 ， 如 10Mbps 的 标准 以 太 网 、100Mbps 
的 快速 以 太 网 、1Gbps 的 千 兆 以 太 网 、10Gbps 的 万 兆 以 太 网 ， 现 在 


100Gbps 的 十 万 兆 以 太 网 也 正在 人 印 究 之 中 。 有 天 以 太 网 标准 的 内 容 将 在 


第 6 章 介绍 。 
2. 城 域 网 


城 域 网 (Metropolitan Area Network，MAN) 中 各 计算 机 网 络 设备 
的 地 理 分 布 范 围 介 于 LAN 和 下 面 将 要 介绍 的 广域网 (WAN) 之 间 , 主 
要 遍布 一 个 城市 内 部 ， 所 以 称 之 为 “ 城 域 网 ”。MAN 主 要 是 用 来 在 一 个 
较 大 的 地 理 区 域 (通常 是 10~100 公 里 ) 内 提供 数据 、 声 音 和 图 像 的 传 


征 
输 ， 一 般 是 用 于 提供 公共 服务 的 。 


MAN 的 标准 为 IEEE 802.6， 通 常 采用 AIM 技 术 作为 骨干 网 传输 技 
术 ， 目 前 光纤 技术 也 在 城 域 网 中 得 到 了 广泛 应 用 。ATM 是 一 个 可 同时 
应 用 于 数据 、 语 音 、 视 频 和 其 他 多 媒体 应 用 的 网 络 传输 技术 。 城 域 网 
通常 为 一 个 或 几 个 组 织 所 有 ， 更 多 的 是 为 公众 提供 公共 服务 的 ， 如 城 
市 银行 系统 、 城 市 消防 系统 、 城 市 邮政 系统 、 城 市 有 线 电视 /广播 网 络 
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3. 广 域 网 


广域网 (Wide Area Network，WAN) 是 规模 最 大 的 一 种 计算 机 网 
络 ， 分 布 的 地 理 范 围 可 以 非常 广 ， 如 一 个 或 多 个 城市 ， 或 者 多 个 国 
家 ， 甚 至 可 以 遍布 全 球 。Internet 是 最 大 的 广域网 。 它 遍及 全 球 ， 由 全 
球 许 多 LAN、MAN 互 联 组 成 。WAN 主 要 也 是 为 公众 提供 公共 服务 的 ， 


由 不 同 ISP (Internet 服 务 商 ) 组 建 ， 为 他 们 的 广大 用 户 提 供 各 种 网 络 接 
入 和 应 用 服务 。WAN 具 有 以 下 基本 特性 。 


(1) 覆盖 范围 广 


WAN 所 禾 盖 的 地 理 范围 非常 大 ， 一 般 从 几 百 公里 到 几 千 公里 ， 可 
和 窗 盖 多 个 城市 、 整 个 国家 ， 力 至 全 球 。Intemet 是 最 大 的 广域网 ， 其 他 
的 WAN 又 是 Internet 的 核心 。 在 广域网 中 通常 使 用 的 是 公 网 了 地 址 (这 
种 地 址 是 需要 购买 并 注册 的 ) 。 当 然 ，WAN 互 连 的 各 局 域 网 内 部 仍 可 
使 用 供 局 域 网 私 用 的 IP 地 址 。 


(2) 构建 成 本 高 


由 于 WAN 地 理 范 围 广 ， 网 络 线路 很 长 ， 介 质 类 型 多 种 多 样 ， 而 且 
铺设 非常 困难 ， 所 以 单独 组 建 一 个 WAN 的 成 本 非常 昂贵 ， 所 以 通常 借 
用 传统 的 公共 传输 (电报 、 电 话 ) 网 这 个 平台 来 实现 。 


(3) 网 络 结构 和 类 型 复杂 


由 于 WAN 连 接 了 多 个 远程 网 络 ， 所 以 网 络 结构 非常 复 洒 、 网 络 类 
型 也 可 能 不 一 样 ， 所 以 需要 解决 不 同 结构 和 不 同类 型 网 络 之 间 的 互 连 


的 问题 。 


(4) 传输 速率 低 ， 误 码 率 高 


由 于 WAN 的 传输 距离 远 ， 又 依靠 传统 的 公共 传输 网 ， 所 以 误 码 率 
较 高 (一 般 在 10 ~10” 之 间 ) ， 传 输 速 率 较 低 (通常 是 100Mbps 以 
) o 


图 2-8 显 示 了 局 域 网 、 城 域 网 和 广域网 三 痢 之 间 的 典型 天 系 。 其 中 
的 “ 接 入 网 ”是 位 于 局 域 网 与 城 域 网 或 广域网 之 间 的 中 间 小 型 网 络 ， 专 
门 为 远程 网 络 间 互 连 提供 网 络 用 户 接 入 技术 ， 如 各 种 ISP (Intermet 服 务 
商 ) 为 我 们 提供 的 ADSL 拨 号 、 光 纤 接 入 、 分 组 接 入 、 卫 星 接 入 ， 以 及 
各 种 专线 接 入 等 。 
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图 2-8 局 域 网 、 城 域 网 和 广域网 之 间 的 关系 


2.2.2” 按 网 络 管理 模式 分 


按 计算 机 网 络 的 管理 模式 可 以 把 目前 的 计算 机 网 络 划 分 为 对 等 网 
(Peer-to-Peer，PTP) 和 C/S (Client/Server， 客 户 机 /服务 器 ) 网 。 


1. 对 等 网 


所 谓 “ 对 等 网 ”(PTP) ， 即 网 络 中 各 成 员 计 算 机 的 地 位 都 是 平等 
的 ， 没 有 管理 与 被 管理 之 分 。 计 算 机 各 目 为 政 ， 谁 也 不 管 谁 ， 采 用 的 
是 分 散 管 理 模 式 。 殉 像 日 闻 的 一 些小 沙龙 一 样 ， 沙 龙 中 各 成 员 坪 平等 
的 ， 大 家 组 织 在 一 起 仅 为 了 相互 交流 。 对 等 网 中 的 每 台 计 算 机 都 既 可 
以 作为 其 他 计算 机 资源 访问 的 服务 占 ， 叉 可 作为 工作 站 来 访问 其 他 计 
算 机 ， 整 个 网 络 中 没有 专门 的 资源 服务 器 ， 如 图 2-9 所 示 。 最 简单 的 对 
等 网 可 以 仅 通 过 串 行 线 线 〈 称 为 零 调制 解 调 需 ) 来 连接 两 全 计算机 。 


对 等 网 可 以 说 是 当今 最 简单 的 网 络 ， 远 没有 像 windows 域 网 络 那样 
的 C/S 网 络 配置 复杂 ， 非 营 适 合家 庭 、 校 园 和 小 型 办 公 室 用 户 。 从 用 户 
和 计算 机 管理 角度 来 看 ， 通 过 Linux 和 UNIX 操 作 系 统 组 成 的 计算 机 网 
络 都 采用 这 种 网 络 管理 模式 ，Windows 操 作 系统 中 的 “工作 组 网络 也 是 
对 等 网 管理 模式 。 但 要 注意 的 是 ， 即 使 在 对 等 网 中 ， 也 可 能 有 部 分 服 
务 是 采用 C/S 管 理 模式 的 ， 如 在 工作 组 网 络 中 部 嗜 的 文件 服务 磊 、 数 据 
库存 服务 器 、 邮 件 服务 器 等 。 


客户 机 
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客户 机 
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图 2-9 对 等 网 示例 


对 等 网 除 具 有 配置 商 单 的 优点 之 外 ， 更 多 的 征 不 足 ， 主 要 体现 在 
Di 


(1) 配置 与 管理 困难 


因为 采用 的 是 分 散 管理 模式 ， 所 以 对 等 网 络 管理 员 无 法 做 到 通过 
一 合计 算 机 集中 管理 网 络 中 的 用 户 、 计 算 机 和 其 他 资源 ， 更 难以 对 网 
络 中 的 用 户 计算 机 进行 统一 配置 。 


(2) 安全 性 差 


同样 是 因为 对 等 网 采用 分 散 管理 模式 ， 给 整个 网 络 (特别 是 企业 
网 络 ) 的 安全 性 带 来 了 巨大 挑战 。 因 为 在 这 种 计算 机 网 络 中 ， 企 业 数 
据 分 获 保 存在 各 用 户 计算 机 上 ， 很 难 十 分 有 效 地 为 每 一 用 户 计算 机 配 
置 高 级 的 安全 保护 措施 。 


(3) 成 本 高 


表面 上 看 对 等 网 不 需要 服务 器 ， 成 本 会 更 低 ， 事 实 上 不 完全 是 这 
样 ， 特 别 是 对 于 有 一 定 规 模 的 企业 网 络 。 因 为 企业 数据 是 分 散在 各 用 
户 计算 机 上 存储 和 管理 的 ， 随 着 时 间 的 推移 ， 可 能 需要 为 每 个 用 户 计 
算 机 配备 较 大 容量 的 磁盘 ， 浪 费 了 磁盘 空间 。 如 果 要 再 为 每 个 用 户 配 
备 相应 的 安全 保护 措施 ， 这 成 本 就 更 高 了 。 


(4) 性 能 差 


在 对 等 网 中 ， 各 用 户 计算 机 的 网 络 连接 性 能 、 数 据 处 理性 能 和 磁 
盘 读 取 性 能 基本 上 一 样 ， 而 且 通 常 只 钙 普 通 的 性 能 ， 再 加 上 各 用 户 计 
算 机 之 间 可 能 因 一 些 数据 共享 而 逢 频繁 访问 ， 所 以 对 等 网 的 网 络 通信 
和 数据 读 取 性 能 就 只 能 算 一 般 了 。 而 在 下 面 将 要 介绍 的 C/S 模 式 网 络 
中 ， 服 务 器 的 网 络 连接 性 能 、 数 据 处 理性 能 和 磁盘 读 取 性 (通常 是 采 
用 服务 器 专用 磁盘 ) 能 都 比较 高 ， 而 且 用 户 间 的 访问 通常 比较 少 ， 所 
以 C/S 网 络 的 整体 网 络 性 能 往往 会 更 高 。 


2.C/S 网 


C/S 模 式 其 实 是 针对 具体 服务 器 功能 来 说 的 ， 这 些 服务 器 可 以 是 用 
于 管理 整个 计算 机 网 络 中 计算 机 和 用 户 账户 的 服务 器 (如 Windows 域 网 
络 中 的 域 控制 器 ) ， 也 可 以 是 其 他 网 络 或 应 用 服务 器 (如 邮件 服务 
器 、 数 据 库 服务 器 、Web 服 务 器 、FTP 服 务 器 等 ) 。 这 些 服 务 器 有 一 个 
共同 的 特点 ， 就 是 一 般 只 作为 服务 器 角色 而 存在 ， 专 门 为 网 络 中 其 他 
用 户 计算 机 提供 对 应 的 服务 。 这 相当 于 我 们 现实 生活 中 每 个 组 织 、 每 
个 部 门 都 有 一 个 或 多 个 管理 者 一 样 ， 他 们 负责 的 就 是 对 对 应 的 组 织 或 
部 门 进 行 管理 。 图 2-10 所 示 的 就 是 一 个 单 台 服 务 器 的 C/S 网 ， 而 图 2-11 
所 示 的 是 一 个 具有 多 台 不 同类 型 服务 器 的 C/S 网 。 
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图 2-10 单 服务 器 的 C/S 网 
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图 2-11 多 服务 器 的 C/S 网 


C/S 网 的 杰出 代表 就 是 Windows 服 务 器 系统 (如 Windows Server 
2003、Windows Server 2008 等 ) 的 域 网 络 。 这 种 域 网 络 可 以 对 网 络 中 
的 所 有 用 户 、 计 算 机 账户 进行 统一 管理 。 除 此 之 外 ， 各 种 其 他 网 络 服 
务 器 〈 如 DNS 服务 器 、DHCP 服 务 器 、NFS 服 务 器 等 ) 和 应 用 服务 器 

(如 Web 服 务 器 、FTP 服 务 器 、E-mail 服 务 器 等 ) 也 可 以 组 成 CS 网 ， 不 
过 它们 不 能 集中 管理 网 络 中 的 用 户 和 计算 机 账户 。 


综合 起 来 ，C/S 网 络 的 主要 优点 如 下 : 


(1) 管理 和 配置 容易 


在 C/S 网 中 ， 用 户 账户 往往 可 以 集中 管理 ， 在 服务 右上 的 配置 可 能 
稍微 复杂 一 些 ， 但 在 客户 端的 配置 却 非常 简单 ， 对 于 Windows 域 网 络 ， 
更 是 可 以 集中 管理 整个 网 络 中 的 用 户 和 计算 机 账户 。 


(2) 安全 性 高 


同样 是 因为 在 服务 右上 集中 管理 了 用 户 账户 、 计 算 机 账户 、 企 业 
数据 ， 乃 至 整个 网 络 的 安全 策略 ， 所 以 整个 网 络 的 安全 性 较 高 。 


分 

理 设备 、 高 带宽 端口 和 高 性 能 磁盘 (通常 还 使 用 性 能 和 安全 性 更 高 的 
磁 副 阵列 ) ， 所 以 整个 网 络 中 尽管 用 户 会 集中 频繁 访问 服务 

整体 网 络 性 能 来 讲 ， 仍 比 对 等 网 模式 要 高 。 


C/S 网 对 于 小 型 企业 来 说 ， 因 为 要 专门 配备 高 性 能 的 服务 器 ， 所 以 
成 本 还 是 有 些 高 。 但 对 于 稍 有 一 些 规模 的 企业 网 络 来 说 ， 这 点 成 本 其 
实 完全 可 以 从 各 用 户 计算 机 磁 僵 容量 成 本 中 节省 出 来 ， 因 为 有 了 专门 
的 服务 万 后 ， 各 用 户 计 算 机 的 磁盘 容量 可 以 小 许多 ， 目 然 总 成 本 束 低 
了 许多 。 目 前 各 企业 基本 上 都 采用 的 是 CS 网 ， 因 为 企业 中 基本 上 都 会 


专门 配置 一 全 甚至 多 台 专 门 的 服务 大 ， 哪 但是 Linux 和 UNIX 操 作 系 统 
网 络 。 
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按 网 络 传输 方式 计算 机 网 络 可 划分 为 点 对 点 传输 网 络 和 广播 式 传 
输 网 络 两 种 。 这 种 划分 方式 其 实 征 根据 所 采用 的 传输 协议 进行 划分 的 
方式 ， 因 为 无 论 是 点 对 点 传输 网 络 ， 还 是 广播 式 传输 网 络 ， 都 主要 取 
决 于 所 采用 的 通信 协议 ， 与 网 络 拓扑 结构 也 有 一 定 的 关系 。 


(1) 点 对 点 传输 网 络 


在 点 对 点 传输 网 络 中 采用 的 通信 协议 都 是 基于 点 对 点 通信 的 ， 如 
SLIP 〈 串 行 线路 Internet 协 议 ) 、PPP (点 对 点 协议 ) 、PPPOE (基于 以 
太 网 的 点 对 点 协议 ) 、PPTP (点 对 点 隧道 协议 等。 我 们 使 用 的 各 种 
Modem 拨 号 (拨号 网 络 的 基本 结构 如 图 2-12 所 示 ) ， 以 及 路 由 器 间 串 
口 (通常 称 为 S 口 ) 的 连接 ， 所 使 用 的 都 是 PPP (点 对 点 协议 ) 或 PPOE 
(以 太 网 点 对 点 协议 ) 。 我 们 打 电 话 也 是 点 对 点 通信 和 的， 通信 只 在 两 
部 电话 机 线路 之 间 进 行 ， 其 他 线路 上 的 用 户 是 听 不 到 的 。 


拨号 客户 端 Modem 公用 电话 Modem 拨号 服务 器 
交换 网 络 


图 2-12 拨号 网 络 基 本 结构 


在 点 对 点 传输 网 络 中 ， 数 据 是 以 点 对 点 的 方式 (或 者 说 是 “一 对 
一 ”方式 ) 在 计算 机 或 通信 设备 中 传输 的 ， 也 就 是 某 个 端口 只 能 和 与 它 
相 接 、 相 和 连 的 对 问 问 口 进行 通信 ， 不 能 把 数据 发 送 到 本 网 络 的 其 他 钱 
路 中 ， 也 就 古 只 能 单 点 “联系?”。 束 像 我 们 在 电视 剧 中 经 营 听 到 的 “单线 
联系 ”一 样 ， 茶 个 人 只 能 与 组 织 中 为 一 个 人 联系 ， 任 何 一 个 下 级 成 员 根 
本 不 知道 整个 组 织 中 其 他 成 员 的 联系 方式 。 


扩 对 所 传输 网 络 是 由 许多 互相 连接 的 市 扩 构成 的 ， 在 每 对 机 器 之 
间 都 有 一 条 专用 的 通信 信道 ， 也 就 古 说 这 两 台 机 器 是 独占 通信 线路 
的 ， 如 各 种 拨号 网 络 吏 是 这 样 的 。 因 此 在 点 对 点 传输 网 络 中 ， 不 存在 
言 道 共享 与 复 用 的 情况 。 


(2) 广播 式 传输 网 络 


广播 式 传输 网 络 是 一 种 可 以 仅 使 用 由 网 络 上 的 所 有 节点 共享 的 公 
共 信 道 进行 广播 传输 的 计算 机 网 络 ， 是 一 种 一 点 对 多 点 的 网 络 结构 。 
图 2-13 束 是 一 个 广播 式 传输 网 络 示例 ， 图 中 PC1 机 发 送 一 个 广播 包 ， 可 
以 到 达 网 络 中 其 他 任何 PC 机 上 。 
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图 2-13 广播 式 传输 网 络 示例 


在 广播 式 传输 网 络 中 传输 信息 时 ， 任 何 一 个 节点 都 可 以 发 送 数据 
包 ， 通 过 公共 信道 (如 交换 机 的 背 板 矩阵 ， 以 及 设备 间 的 连接 通道 ) 
或 总 线 传 送 到 网 络 中 的 其 他 计算 机 上 。 然 后 ， 这 些 计 算 机 根据 数据 包 
中 的 目的 MAC 地 址 进行 判断 ， 如 果 目 己 的 MAC 地 址 与 目的 MAC 地 址 匹 
配 则 接收 “与 此 同时 ， 发 送 节 点 就 可 以 知道 与 目的 耳 地 址 对 应 的 MAC 
地 址 ， 下 次 接收 到 包括 同样 目的 IP 地 址 的 包 时 就 不 用 再 广播 了 ) ， 否 
则 便 丢 弃 它 。 


区 分 是 哪 种 传输 方式 网 络 ， 最 关键 的 是 看 它 里 面 所 用 的 通信 协 
议 。 以 太 网 藉 是 典型 的 广播 式 传输 网 络 ， 其 所 使 用 的 吏 是 各 种 以 太 网 
(Ethernet) 协议 。 本 章 后 面 将 要 介绍 的 环形 拓扑 结构 的 令 牌 环 网 络 和 


总 线 型 拓扑 结构 的 令 牌 总 线 网 络 也 是 广播 式 传输 网 络 ， 因 为 在 这 两 种 
拓扑 结构 网 络 中 ， 任 何 一 个 站 点 发 送 数据 ， 其 他 站 点 都 可 以 接收 到 ， 

总 线 两 端的 计算 机 是 存在 公共 传输 通道 的 ， 这 条 公共 传输 通道 束 旦 那 
条 总 线 。 当 然 ， 不 仅 环形 、 总 线 型 拓扑 结构 的 网 络 可 以 是 广播 式 网 

络 ， 其 他 的 像 星 型 、 树 型 、 网 状 拓扑 结构 的 计算 机 网 络 部 可 以 是 广播 
式 传输 网 络 ， 因 为 这 些 网 络 中 都 存在 公共 信道 。 各 种 无 线 网 络 、 卫 星 
传播 网 络 也 都 是 广播 式 传输 网 络 的 ， 因 为 它们 的 传输 信道 都 是 公用 

的 。 具 体 的 网 络 拓 扑 结构 将 在 下 市 介绍 。 


2.3 计算 机 网 络 拓扑 结构 


拓扑 (Topology) 学 是 一 种 研究 与 大 小 、 距 离 无 关 的 几何 图 形 特 
性 的 方法 。* 网 络 拓扑 结构 ?是 由 网 络 世 点 设备 和 通信 介质 通过 物理 连 
接 所 构成 的 逻辑 结构 图 。 网 络 拓扑 结构 是 从 逻辑 上 表示 网 络 服务 做 、 
工作 站 的 网 络 配置 和 互相 之 间 的 连接 方式 和 服务 关系 。 在 选择 拓扑 结 
构 时 ， 主 要 考虑 的 因素 有 : 不 同 设备 所 担当 的 角色 (或 者 设备 间 服 务 
的 关系 ) 、 各 市 点 设备 工作 性 能 要 求 、 安 装 的 相对 难 易 程度 、 重 新 配 
置 的 难 易 程 度 、 维 护 的 相对 难 易 程度 、 通 信介 质 发 生 故 障 时 受到 影响 
的 设备 的 情况 。 


本 市 要 分 别 介 绍 计算 机 网 络 (包括 局 域 网 和 广域网 ) 中 的 一 些 主 
要 拓扑 结构 。 在 此 先 介 绍 与 网 络 拓 扑 结构 有 关 的 儿 个 基本 概念 。 


2.3.1 网络 拓 扑 结 构 相 关 基 本 概念 
在 设计 网 络 拓扑 结构 时 ， 我 们 经 常会 遇 到 如 “节点 "”、“ 结 点 ”、“ 链 


路 ”和 “通路 ”这 四 个 术语 。 它 们 a 到底 各 目 代 表 什 么 ， 它 们 之 间 义 有 什么 
天 系 呢 ? 


(1 节 高 


一 个 “ 字 扩 ”其实 谍 是 一 个 网 络 端 口 。 市 点 义 分 为 “ 转 市 态 ” 和 “访问 
节操 ”两 类 。“ 转 节 扣 ”的 作用 古文 持 网 络 的 连接 ， 它 通过 通信 线路 转 接 
和 传递 信息 ， 如 交换 机 、 网 天 、 路 由 右 、 防 火 墙 设备 的 各 个 网 络 闻 口 
等 ， 而 “访问 节操 ” 是 信息 交换 的 源 点 和 目标 点 ， 通 第 十 用 户 计算 机 上 
的 网 卡 接口 。 如 我 们 在 设计 一 个 网 络 系统 时 ， 通 常 所 说 的 共有 xx 个 节 
上 态 ， 其 实 束 古 在 网 络 中 有 多 个 要 配置 IP 地 址 的 网 络 逆 口 。 


人 


一 个 “ 结 点 "是 指 一 合 网络 设备 ， 因 为 它们 通 稼 连接 了 多 个 “有 
点 ”， 所 以 称 之 为 " 绪 点 ”。 在 计算 机 网 络 中 的 结 点 又 分 为 链 路 结 点 和 路 
由 结 点 ， 它 们 整 分 别 对 应 的 古 网 络 中 的 交换 机 和 路 由 器。 从 网 络 中 的 
结 点 数 多 少 束 可 以 大 概 知 道 你 的 计算 机 网 络 规模 和 基本 结构 了 。 


(3) 链 路 


“ 链 路 "是 两 个 节点 间 的 线路 。 链 路 分 物理 链 路 迁 辑 链 路 (或 称 
数据 链 路 ) 两 种 ， 前 者 是 指 实际 存在 的 通信 线路 ， 由 设备 网 络 端口 和 
传输 介质 连接 实现 ， 后 者 是 指 在 逻辑 上 起 作用 的 网 络 通路 ， 由 计算 机 
网 络 体系 结构 中 的 数据 链 路 层 标 准 和 协议 来 实现 。 如 采 链 路 层 协议 没 
有 起 作用 ， 数 据 链 路 也 莽 无 法 建立 起 来 。 


(4) 通路 


“通路 ”从 发 出 信息 的 让 点 到 接收 信息 的 节点 之 间 的 一 串 节 把 和 链 
路 的 组 合 。 也 束 是 说 ， 它 是 一 系列 穿越 通信 网 络 而 建立 起 来 的 节点 到 
节 扩 的 链 路 串 连 。 它 与 “ 链 路 ”的 区 别 主 要 在 于 一 条 “通路 ”中 可 能 包括 


多 条 “ 链 路 ”。 


2.3.2” 星 型 折 扑 结构 


星 型 拓扑 结构 (Star Topology) 又 称 集中 式 拓 扑 结构 ， 和 是 因 集 线 需 
或 交换 机 连接 的 各 节点 呈 星 状 (也 就 是 放射 状 ) 分 布 而 得 名 。 在 这 种 
拓扑 结构 的 网 络 中 有 中 央 结 点 集线器， 或 交换 机 ) ， 其 他 节点 ( 工 
作 站 、 服 务 右 ) 部 与 中 央 结 点 直接 相连 。 


1. 基 本 星 型 拓扑 结构 单元 


星 型 拓扑 结构 是 目前 应 用 最 广 、 实 用 性 最 好 的 一 种 拓扑 结构 ， 这 
主要 是 因为 它 非 常 容易 实现 网 络 的 扩展 。 无 论 在 局 域 网 中 ， 还 是 在 广 
域 网 中 都 可 以 见 到 它 的 身影 ， 但 其 主要 还 是 应 用 于 有 线 以 太 局 域 网 
中 。 所 以 事实 上 ， 星 型 拓扑 结构 主要 应 用 于 以 太 局 域 网 中 ， 以 太 网 包 
括 许 多 标准 ， 对 应 的 标准 集 就 是 IEEE 802.3， 具 体 将 在 第 6 章 介 绍 。“ 星 
型 拓扑 结构 ”其实 只 是 一 个 结构 单元 (一 台 和 集线器 ， 或 者 交换 机 设备 就 
是 一 个 星 型 结构 单元 ) ， 多 个 星 型 结构 单元 连接 起 来 又 可 以 形成 下 面 
将 要 介绍 的 “ 树 型 拓扑 结构 ”。 图 2-14 所 示 的 是 最 简单 的 单 台 集 线 器 或 交 
换 机 星 型 拓扑 结构 单元 。 


二 
作 


集线器 / 交换 机 
站 


图 2-14 基本 星 型 拓扑 结构 单元 示例 


在 这 个 星 型 拓扑 结构 单元 中 ， 所 有 服务 右 和 工作 站 等 网 络 设备 都 
集中 连接 在 同一 台 交 换 机 上 “。 因 为 现在 的 固定 端口 交换 机 最 多 可 以 有 
48 个 或 以 上 交换 问 口 ， 所 以 这 样 一 个 商 单 的 星 型 网 络 完全 可 以 适用 于 
用 户 节 点 数 在 40 个 以 内 的 小 型 企业 ， 或 者 分 支 办 公 室 选 用 。 模 块 式 的 
交换 机 端口 数 可 达 100 个 以 上 ， 可 以 满足 一 个 小 型 企业 的 需求 。 但 实际 
上 这 种 连接 方式 是 比较 少见 的 ， 因 为 单独 用 一 台 模 块 式 的 交换 机 连接 
成 本 要 远 高 于 采用 多 人 台 低 端口 密度 的 固定 端口 交换 机 级 联 方式 。 模 块 
式 交 换 机 通常 用 于 大 中 型 网 络 的 核心 层 (或 骨干 层 ) 或 汇聚 层 ， 小 型 
网 络 很 少 使 用 。 


扩展 交换 端口 的 为 一 种 有 效 方法 就是 堆 厨 了 。 有 一 些 固 定 闪 口 配 
置 的 交换 机 文 持 堆 县 技术 ， 通 过 专用 的 堆 受 电缆 连接 ， 所 有 堆 受 在 一 
起 的 交换 机 都 可 作为 单一 交换 机 来 管理 ， 不 仅 可 以 使 端口 数量 得 到 大 
幅 提 高 《通常 最 多 堆 受 8 台 ) ， 还 可 以 提高 堆 县 交换 机 中 各 端口 实际 可 


用 的 背 板 帝 宽 ， 提 高 了 交换 机 的 整体 交换 性 能 。 


有 关 交 换 机 的 级 联 和 堆 徐 技术 及 配置 的 具体 内 容 可 参见 笔者 的 
《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 (第 2 版 ) 一 书 。 


2. 多 级 星 型 拓扑 结构 


复杂 的 星 型 结构 网 络 就 是 在 图 2-14 基 础 上 通过 多 台 交 换 机 级 联 形 成 


的 ， 从 而 形成 多 级 星 型 拓扑 结构 ， 满 足 更 多 、 不 同 地 理 位 置 分 布 的 用 
户 连 接 和 不 同 端口 带宽 和 需求。 其实 这 就 是 下 面 将 要 介绍 的 “ 树 型 拓扑 结 
构 ”。 图 2-15 是 一 个 包含 两 级 交换 机 结构 的 星 型 网 络 ， 其 中 的 两 层 交 换 
机 通常 为 不 同 档 次 的 ， 可 以 满足 不 同 需 求 。 核 心 (或 骨干 层 ) 交换 机 
要 选择 档次 较 高 的 ， 用 于 连接 下 级 交换 机 、 服 务 器 和 有 高 性 能 需求 的 
工作 站 用 户 等 ， 下 面 各 级 则 可 以 依次 降低 要 求 ， 以 便 最 大 限度 地 市 省 
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图 2-15 两 级 星 型 拓扑 结构 示例 


当然 ， 在 实际 的 大 中 型 企业 网 络 中 ， 其 网 络 结构 可 能 要 比 图 2-15 所 
示 的 网 络 复杂 许多 ， 还 可 能 有 三 级 ， 甚 至 四 级 交换 机 的 级 联 (通常 最 
多 部 署 四 级 ) ， 还 可 能 有 交换 机 的 堆 琶 和 集群 。 图 2-16 所 示 网 络 结构 中 
SS3 Switch 4400 位 置 就 是 由 两 台 这 样 的 交换 机 堆肥 组 成 的 。 


核心 交换 机 | SS3 Switch 4900 


~ 边缘 交换 机 
国 ) : 


< 


图 2-16 包含 交换 机 堆 释 的 星 型 拓扑 结构 示例 
3. 星 型 拓扑 结构 传输 距离 限制 


因为 在 星 型 结构 网 络 中 通常 是 采用 双 绞 线 和 光纤 作为 传输 介质 
的 ， 而 单 段 双 绞 线 的 最 大 长 度 为 100m， 集 线 设 备 放置 在 中 心 点 ， 这 样 
每 一 个 采用 此 种 结构 的 集 线 设备 所 能 连接 的 网 络 范 围 最 大 直径 就 达到 
200m， 超 过 这 个 范围 都 将 要 采用 级 联 或 中 继 的 方法 。 采 用 光纤 作为 传 
输 介 质 时 虽然 传输 距离 可 以 长 许多 ， 但 也 是 有 限制 的 。 各 种 连接 电线 
长 度 限制 如 表 2-1 所 示 ，1000BASE-SX 网 络 的 光纤 长 度 限 制 如 表 2-2 所 


尔 。 


表 2-1 各 种 以 太 网 电缆 长 度 限 制 
以 太 网 标准 电缆 类 型 单 段 最 大 长 度 /km 网 络 接口 类 型 


10BASE-T 3、4、5 类 100 欧 UTP (〈 非 屏蔽 双 绞 线 ) 0.1 RJ-45 
100BASE-T 5 类 100 欧 UTP RJ-45 
1000BASE-SX 50/125 或 62.5/125 微米 多 模 光 纤 (MMEF) 参见 表 2-2 SC 或 ST 
1000BASE-LH 9/125 微米 单 模 光 纤 (SMF) SC 或 ST 
5 
.1 


1000BASE-LX 91125 做 洲 SMF EE sw 
1000BASE-T | 5 类 超 5 类 或 6 类 UTP RI 


表 2-2 1000BASE-SX 光纤 长 度 限 制 


光纤 直径 /am 光纤 带宽 / (MHz/km) 单 段 最 大 长 度 /m 

220 
62.5/125 MMF 

275 

500 
50/125 MMF 

550 


经 验 之 谈 许多 读 首 朋友 认为 ， 星 型 拓扑 结构 只 适用 于 同 楼 层 的 
网 络 ， 其 实 不 是 这 样 的 。 在 多 楼 层 ， 甚 至 多 栋 建 筑 物 之 间 的 网 络 互 连 
多 数 也 可 以 采用 星 型 拓扑 结构 ， 因 为 它 具 有 非常 高 的 传输 速率 。 从 表 2- 
1 和 表 2-2 可 以 看 出 ， 各 楼 层 之 间 ， 各 建筑 物 之 间 都 可 以 采用 普通 的 双 绞 
线 进行 连接 《通常 是 大 对 数 的 )  ， 只 要 距离 在 双 绞 线 的 有 效 距离 范围 
内 ; 当 超 过 了 双 绞 线 的 有 效 距 离 后 ， 可 以 采用 光纤 连接 (光纤 的 传输 
距离 更 远 ， 传 输 性 能 更 好 ) ， 但 光纤 介质 和 相应 接口 的 设备 价格 更 
贯 ， 这 必须 予以 充分 考虑 。 同 轴 电 缆 只 是 一 种 低 成 本 、 低 性 能 的 选 
择 ， 因 为 它 的 传输 性 能 要 远 低 于 双 绞 线 和 光纤 ， 在 目前 实际 的 楼 层 和 
建筑 物 之 间 网 络 互 连 很 少 采 用 。 


4. 星 型 拓扑 结构 主要 优 缺 点 


星 型 拓扑 结构 的 优点 主要 体现 在 以 下 几 个 方面 : 
(1) 市 点 扩展 、 移 动 方便 


在 星 型 拓扑 结构 网 络 中 ， 节 点 扩展 时 只 需要 从 交换 机 等 集中 设备 
空余 端口 中 拉 一 条 电费 与 要 加 入 的 万 点 连接 上 即 可 ; 而 要 移动 一 个 节 
点 只 需要 把 相应 节点 设备 连接 网 线 从 设备 端口 拔 出 ， 然 后 移 到 新 设备 
端口 即 可 。 上 述 过 程 并 不 影响 其 他 任何 己 有 设备 的 连接 和 使 用 ， 不 会 
像 下 面 将 要 介绍 的 环形 网 络 那样 “ 率 一 发 而 动 全 号?”。 这 征 星 型 拓扑 结 
构 的 最 大 优势 。 


、 


(2) 网 络 传输 数据 快 


因为 整个 网 络 呈 星 型 连接 ， 网 络 的 上 行 通道 不 是 共享 的 ， 所 以 每 
个 节操 的 数据 传输 对 其 他 市 点 的 数据 传输 影响 非 第 小 ， 这 样 束 加 快 了 
网 络 数据 传输 速度 。 


另外 ， 星 型 拓扑 结构 所 对 应 的 双 绞 线 和 光纤 以 太 网 标准 的 传输 速 
率 可 以 非常 高 “主要 是 因为 相应 的 网 络 技术 发 展 非 常 快 ) ， 如 普通 的 5 
类 、 超 5 类 都 可 以 通过 4 对 芯 线 实现 1000Mbps 传 输 速率 ，7 类 屏蔽 双 绞 线 
则 可 以 实现 10Gbps 传 输 速 率 ， 光 纤 则 更 是 可 以 轻松 实现 千 兆 、 万 兆 的 
传输 速率 。 而 后 面 要 介绍 的 环形 、 总 线 型 结构 中 所 对 应 的 标准 速率 都 
在 16Mbps 以 内 ， 明 显 低 了 许多 。 


(3) 维护 容易 


在 星 型 网 络 中 ， 每 个 节点 都 是 相对 独立 的 ， 一 个 市 点 出 现 故 障 不 
会 影响 其 他 节点 的 连接 ， 可 任意 拆 走 故 障 节 点 。 正 因 如 此 ， 这 种 网 络 
结构 受到 用 户 的 普 过 欢迎 ， 成 为 应 用 最 广 的 一 种 拓扑 结构 类 型 。 但 如 
朱 集 线 设备 出 现 了 故障 ， 也 会 导致 整个 网 络 的 次 痪 。 


星 型 拓扑 结构 的 缺点 主要 体现 在 如 下 几 个 方面 。 


(1) 核心 交换 机 工作 负荷 重 


虽然 说 各 工作 站 用 户 连 接 的 是 不 同 的 交换 机 ， 但 走 最 终 还 是 要 与 
连接 在 网 络 中 央 核 心 交 换 机 上 的 服务 右 进 行 用 户 登 录 和 网 络 服务 紫 访 
问 操 作 ， 所 以 中 央 核 心 交 换 机 的 工作 负 倚 相当 莹 重 ， 故 对 担任 中 央 设 
备 的 交换 机 的 性 能 和 可 靠 性 的 要 求 非 常 高 。 其 他 各 级 集线器 和 交换 机 
也 连接 多 个 用 户 ， 其 工作 负荷 同样 非常 重 ， 也 要 求 具有 较 高 的 可 靠 
性 有 


(2) 网 络 布线 较 复 杂 


每 个 计算 机 直接 及 用 专门 的 电 统 与 集 线 设备 相连 ， 这 样 整个 网 络 
中 至 少 就 需要 所 有 计算 机 及 网 络 设备 总 量 以 上 条 数 的 电缆 ， 这 使 得 结 
构 本 束 非 第 复 末 的 星 型 网 络 变 得 更 加 复 光 了。 特别 十 在 大 中 型 企业 网 
络 的 机 房 中 ， 太 多 的 电缆 无 论 对 维护 、 管 理 ， 还 是 对 机 房 安 全 都 是 一 


个 威胁 。 这 束 要 求 我 们 在 布线 时 要 多 加 注意 ， 一 定 要 在 各 条 电缆 、 集 
线 器 和 交换 机 端口 上 做 好 相应 的 标记 。 同 时 建议 做 好 整个 布线 系统 的 
标记 和 记录 ， 以 备 日 后 出 现 布 线 故 障 时 能 迅速 找到 故障 发 生 点 。 男 
外 ， 由 于 这 种 星 型 网 络 中 的 每 条 电缆 都 是 专用 的 ， 利 用 率 不 高 ， 在 较 
大 的 网 络 中 ， 这 种 浪费 还 古 相当 大 的 。 


(3) 广播 传输 影响 网 络 性 能 


其 实 这 是 以 太 网 的 一 个 不 足 ， 但 因 星 型 拓扑 结构 主要 应 用 于 以 太 
网 中 ， 所 以 相应 的 也 吏 成 了 星 型 网 络 的 一 个 缺点 。 因 为 在 以 太 网 中 ， 
当 集 线 夷 收 到 和 点 发 送 的 数据 时 ， 采 取 的 是 广播 发 送 方 式 ， 任 何 一 个 
所 发送 信息 在 整个 网 中 的 节点 都 可 以 收 到 ， 这 疡 重 影响 了 网 络 性 能 
的 发 挥 。 虽 然 说 交换 机 具有 MAC 地 址 “学 习 ? 功 能 ， 但 对 于 那些 以 前 没 
有 识别 的 节点 发 送 来 的 数据 ， 同 样 是 采取 广播 方式 发 送 的 ， 所 以 同样 
存在 广播 风 骏 的 负面 影响 。 当 然 区 换 机 的 广播 影响 要 远 比 集 线 硕 的 要 
小 得 多 ， 在 局 域 网 中 使 用 影响 不 大 。 


综 上 所 述 ， 星 型 折 扑 结构 站 一 种 应 用 广泛 的 有 线 局 域 网 拓扑 结 
构 ， 特 别 是 它 可 以 采用 廉价 的 双 绞 线 进 行 布线 ， 而 且 是 非 共 享 传输 通 
道 ， 传 输 性 能 好 ， 市 点 数 不 受 技术 限制 ， 扩 展 和 维护 容易 ， 所 以 它 又 
古 一 种 经 济 、 实 用 的 网 络 拓扑 结构 。 但 受到 单 段 双 绞 网 线 长 度 必须 在 
100m 以 内 的 限制 ， 超 过 这 个 距离 则 需要 采取 交换 机 级 联 拓展 方式 ， 或 


者 采用 成 本 较 高 的 光纤 作为 传输 介质 〈 不 仅 是 传输 介质 的 改变 ， 相 应 
设备 也 要 有 相应 的 接口 ) 。 


2.3.3 “环形 拓扑 结构 


环形 拓扑 结构 (Ring Topology) 在 20 世 纪 90 年 代 计 算 机 网 络 刚 开 
始 进 入 国内 时 采用 得 比较 多 ， 应 用 的 标准 是 IEEE 802.5。 可 以 说 ， 令 牌 
环 在 物理 上 是 一 个 由 一 系列 环 接 口 ( 称 之 为 中 继 转 发 侨 ， 即 RPU) 和 
这 些 接 口 间 的 点 对 点 链 路 构成 的 闭合 环 路 ， 各 站 点 PC 通过 环 接 口 连 到 
网 上 。 目 前 这 一 网 络 拓扑 结构 形式 已 不 用 了 ， 因 为 它 的 传输 速率 最 高 
只 有 16Mbps， 扩 展 性 能 又 不 好 ， 早 已 被 性 能 远 超 过 它 的 星 型 拓扑 结构 
双 绥 线 以 太 网 奉 代 了 。 


1. 环 形 网 络 结构 概述 


环形 网 络 拓扑 结构 主要 应 用 于 采用 同 轴 电 统 作 为 传输 介质 的 令 牌 
网 中 ， 图 2-17 束 是 一 个 典型 的 环形 网 络 。 笔 者 曾 于 2000 年 为 一 家 小 型 公 
司 组 建 过 局 域 网 ， 该 局 域 网 采用 的 就 是 这 种 结构 的 。 这 种 网 络 中 的 每 
一 站 点 都 是 通过 环 中 继 转发 郁 与 它 左 右 相 邻 的 站 点 串 行 连接 起 来 的 ， 
在 传输 介质 环 的 两 端 各 加 上 一 个 阻抗 匹配 器 ( 义 称 终端 匹配 器 就 形 
成 了 一 个 封闭 的 环 路 , “环形 ”结构 的 命名 起 因 束 在 于 此 了 。 在 细 同 轴 
电 顷 环 形 网 中 的 环 中 继 转发 右 是 一 个 BNC 接 头 ， 阻 抗 匹 配 夯 上 的 那个 
链子 样 的 东西 接 在 PC 外 壳 上 (相当 于 接地 ) ， 如 图 2-18 所 示 。 


四 服务 器 


和 


图 2-17 环形 拓扑 结构 网 络 示例 


图 2-18 BNC 中 继 转 发 妖 和 阻抗 匹配 妖 


说 明 图 2-17 只 是 一 种 示意 图 ， 实 际 这 种 拓扑 结构 的 网 络 不 会 是 所 
有 计算 机 真 的 要 连接 成 物理 上 的 环形 ， 其 连 成 的 可 以 是 任意 形状 ， 如 


直线 形 、 半 环形 等 。 这 里 所 说 的 “ 环 "是 从 电气 性 能 上 来 讲 的 ,“ 环 ”的 形 
成 并 不 是 通过 电 绕 两 端 直接 连接 形成 的 ， 而 是 通过 在 环 的 电线 两 端 加 
妆 一 个 阻抗 匹配 瑚 来 实现 的 。 


环形 拓扑 结构 网 络 的 一 个 典型 代表 就 是 采用 同 轴 电 缆 作 为 传输 介 
质 的 IEEE 802.5 的 令 牌 环 网 (Token Ring Network) 。 令 牌 环 拓扑 结构 
最 早 是 由 IBM 推 出 的 ， 传 输 速 率 为 4Mbps 或 16Mbps， 比 当时 只 有 2Mbps 
的 以 太 网 性 能 要 高 出 好 几 倍 ， 所 以 在 当时 得 到 了 广泛 的 应 用 。 但 随 着 
以 太 网 技术 的 跳跃 式 发 展 ， 令 牌 环 网 技术 性 能 不 能 再 适应 时 代 的 要 求 
了 ， 故 逐渐 被 淘汰 出 局 了 。 令 有 牌 环 网 的 传输 原理 是 ，RPU 〈 环 中 继 转 
发 器 ) 从 其 中 的 一 个 环 段 ( 称 为 上 行 链 路 ) 上 获取 帧 中 的 每 个 比特 位 
言 号 ， 然 后 经 过 整形 和 放大 转发 到 另 一 环 段 〈 称 为 下 行 链 路 ) 。 如 果 
帧 中 的 目的 MAC 地 址 与 本 站 点 MAC 地 址 一 致 ， 则 复制 该 MAC 帧 发 送 给 
连接 本 RPU 的 站 点 。 


2. 令 牌 环 网 数据 传输 原理 


令 牌 环 网 中 由 点 对 点 链 路 构成 的 环 路 虽然 不 是 真正 意义 上 的 广播 
媒体 ， 但 令 牌 环 网 上 运行 的 数据 帧 仍 能 被 所 有 的 站 点 接收 到 。 而 且 任 
何 时 刻 仅 允 许 一 个 站 扣发 送 数 据 ， 因 此 理论 上 是 存在 发 送 权 苋 争 问题 
的 ， 这 实际 上 就 是 我 们 将 在 第 6 革 介 绍 的 “介质 争 用 ”问题 。 为 了 解决 这 
个 问题 ， 在 令 牌 环 网 中 使 用 了 一 个 称 之 为 “ 令 脾 ”(Token， 可 以 联想 到 
以 前 武将 出 征 杀 敌 时 手中 拿 的 由 星 上 发 的 帅 印 ， 代 表 一 种 授权 ) 的 特 


殊 的 MAC 控 制 帧 (该 帧 中 有 一 个 比特 位 用 来 标志 令 牌 的 忙 或 内 )  ， 使 
其 沿 铸 环 路 循环 。 并 且 规 定 只 有 获得 “ 令 牌 ”的 站 点 才 有 权 发 送 数 据 帕 
(就 像 战争 中 只 有 一 位 统帅 可 以 获得 “ 帅 印 ”一 样 ) ， 完 成 数据 发 送 后 
立即 释放 令 牌 以 供 其 他 站 点 使 用 。 由 于 环 路 中 只 有 一 个 令 牌 ， 因 此 任 
何 时 刻 至 多 只 有 一 个 站 点 发 送 数据 ， 不 会 产生 冲突 。 但 令 牌 环 网 上 各 
站 点 均 有 相同 的 机 会 获得 令 牌 。 


图 2-19 所 示 的 是 一 个 简单 令 牌 环 网 《注意 ， 这 里 的 环 是 逻辑 意义 上 
的 ， 并 不 是 真正 的 物理 环 ) ， 其 中 连接 了 4 台 机 器 。 现 假设 A 站 点 要 癌 
C 站 点 发 送 数 据 。 下 面 介 绍 A 站 点 的 具体 数据 发 送 流程 。 
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图 2-19 令 牌 环 网 示例 


1) 首先 环 网 中 的 令 牌 是 在 网 上 按照 一 个 方向 循环 流动 的 ， 如 图 2- 
20 所 示 (图 中 的 “T” 代 表 的 就 是 环 网 中 的 “ 令 脾 ”) 。 
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图 2-20 令 牌 在 环 网 上 流动 


2) 当 令 有 牌 转 到 A 站 点 时 ，A 站 点 的 RPU 截 获 该 令 牌 (如 图 2-21 所 
示 ) ， 把 令 牌 的 状态 控制 位 设置 为 1， 代 表 处 于 忙 的 状态 〈 表 示 令 牌 目 
前 已 被 占用 ) ， 同 时 在 令 牌 帧 上 附加 要 发 送 的 数据 帧 沿 着 环 的 路 径 向 
下 发 送出 去 。 当 令 牌 帧 和 数据 帧 组 合 的 信息 帧 (在 此 称 之 为 “信息 
帧 >) 流 经 B 站 点 时 ，B 站 点 把 自己 的 MAC 地 址 与 帧 中 的 目的 MAC 地 址 
进行 比较 ， 发 现 不 匹配 ， 于 是 不 接收 该 数据 帧 ， 继 续 转 发 信息 帧 ， 如 


图 2-22 所 示 。 


, 电 


图 2-21 A 站 点 截获 令 牌 


,时 


图 2-22 B 站 扩 不 接收 信息 帧 


3) 当 信 息 帧 流 经 C 站 点 时 ，C 站 点 也 会 把 自己 的 MAC 地 址 与 帧 中 
的 目的 MAC 地 址 进行 比较 ， 发 现 正好 匹配 ， 于 是 C 站 点 的 RPU 复 制 其 
中 的 数据 帧 ， 并 把 复制 的 数据 帧 传送 给 C 站 点 ， 丢 弃 其 中 的 令 牌 帧 ， 如 
图 2-23 所 示 。 
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图 2-23 “C 站 点 的 RPU 复 制 该 数据 帧 ， 并 把 其 传送 给 C 站 点 


4) 原来 的 信息 帧 继续 癌 下 传递 ， 流 经 D 站 点 时 同样 因 它 的 MAC 地 
址 与 数据 帧 中 的 目的 MAC 地 址 不 匹配 ， 故 不 接收 ， 信 息 帧 继续 转 ， 直 
到 回 到 源 站 点 A， 如 图 2-24 所 示 。 


图 2-24 信息 帧 返回 源 站 点 ， 并 释放 令 牌 


此 时 恰好 循环 一 周 ，A 站 点 根据 返回 的 有 关 信 息 确定 所 传 数据 帧 有 
无 出 错 。 硅 有 错 则 重 发 存 于 绥 冲 区 中 的 答 确 认 帧 ， 否 则 释放 缓冲 区 中 
的 等 确认 帆 。 确 认 无 错 后 ，A 站 点 的 RPU 会 把 其 中 的 令 脾 帧 状态 置 为 
0， 表 示 处 于 至 朵 状态 ， 释 放 令 牌 ， 然 后 在 网 上 发 送出 去 ， 令 牌 继续 在 
环 网 上 流动 。 其 他 站 点 如 采 想 要 发 送 数据 ， 则 可 通过 获得 该 令 牌 进行 
数据 发 送 。 


一 个 控制 了 令 牌 的 站 后 可 以 进行 一 次 或 多 次 数据 帧 发 送 ， 只 要 不 
超过 网 络 中 规定 的 最 长 令 牌 控制 时 间 即 可 。 而 具体 的 最 长 令 牌 控制 时 
间 要 视 具 体 网 络 环境 通过 计算 才能 得 出 ， 在 此 不 做 具体 介绍 。 


3. 环 形 拓扑 结构 的 主要 优 缺 点 


环形 拓扑 结构 网 络 的 优点 主要 体现 在 以 下 方面 。 


(1) 网 络 路 径 选 择 和 网 络 组 建 简单 


在 这 种 拓扑 结构 网 络 中 ， 信 息 在 环形 网 络 中 流动 是 沿 着 一 个 特定 
的 方向 ， 每 两 台 计 算 机 之 间 只 有 一 个 通路 ， 简 化 了 路 径 的 选择 ， 路 径 
选择 效率 非常 高 。 同 样 因 为 这 个 ， 这 类 网 络 的 组 建 相 当 简 单 。 


(2) 投资 成 本 低 


在 投资 成 本 方面 ， 主 要 体现 在 令 牌 环 网 络 中 没有 任何 其 他 专用 网 
络 设备 (如 交换 机 ) ， 各 站 点 直接 通过 电缆 连接 ， 所 以 无 需 任 何 投资 
去 购买 网 络 设备 。 


尽管 有 以 上 两 个 看 似 非 党 诱 人 的 优 操 ， 但 环形 网 络 的 缺点 仍 是 主 
要 的 ， 这 也 是 它 最 终 被 淘汰 出 局 的 根本 原因 。 环 形 拓扑 结构 网 络 的 缺 
点 主要 体现 在 以 下 几 个 方面 。 


(1) 传输 速度 慢 


这 是 它 最 终 不 能 得 到 发 展 和 用 户 认可 的 最 根本 原因 。 虽 说 它 在 刚 
出 现时 ， 较 当时 的 10Mbps 以 太 网 在 速度 上 有 一 定 优势 (因为 它 可 以 实 
现 16Mbps 的 接 入 速率 ) ,但 由 于 这 种 网 络 技术 后 来 一 直 没 有 任何 发 


展 ， 速 度 仍 保留 在 原来 水 平 ， 相 对 现在 最 起 码 的 100Mbps、1Gbps 速 率 
的 以 太 网 来 说 ， 实 在 是 太 落 后 了 。 现 在 连 无 线 局 域 网 (WLAN) 的 传 
输 速度 都 远 远 超过 了 它 。 这 么 低 的 连接 性 能 决定 了 它 只 能 被 淘汰 的 局 
面 。 

(2) 连接 用 户 数 非常 少 

在 这 种 环形 拓扑 结构 中 ， 各 用 户 是 相互 串联 在 一 条 传输 电 统 上 
的 ， 所 以 可 以 连接 的 用 户 数 非常 有 限 。 尽 管 可 以 有 中 继 设 备 ， 但 中 继 


器 只 起 到 一 个 信号 放大 和 连接 距离 的 拓展 的 作用 ， 并 不 能 很 明显 地 提 
高 连接 用 户 的 数量 〈 通 常 最 多 也 就 是 几 十 个 用 户 ) 。 


(3) 传输 效率 低 


这 种 环形 拓扑 结构 网 络 共享 一 条 传输 电 绕 ， 每 发 送 一 个 数据 均 要 
先 取 得 令 牌 ， 每 次 数据 的 发 送 ， 令 牌 都 要 在 整个 环 状 网 络 中 从 头 走 到 
尾 ， 哪 旧 是 已 有 站 点 接受 了 数据 ;而 且 每 个 环形 网 络 中 只 有 一 个 令 
牌 ， 所 以 同一 时 刻 只 有 一 个 站 点 可 以 取得 令 牌 并 发 送 数 据 ， 所 以 传输 
效率 是 非常 低 的 ， 明 显 不 再 适用 当前 复杂 的 网 络 应 用 需求 。 


(4) 扩展 性 能 差 


因为 是 环形 拓扑 结构 ， 且 没有 任何 可 用 来 扩展 连接 的 设备 ， 决 定 
了 它 的 扩展 性 能 远 不 如 星 型 拓扑 结构 好 。 如 果 要 新 添加 或 移动 站 点 ， 


就 必须 中 断 整 个 网 络 ， 在 适当 位 置 切断 网 线 ， 并 在 两 端 做 好 环 中 继 转 
发 硕 才 能 连接 。 


(5) 维护 困难 


虽然 在 环形 拓扑 结构 网 络 中 只 有 一 条 传输 电 统 ， 看 似 结构 也 非常 
简单， 但 它 古 一 个 闭环 ， 设 备 者 连接 在 同一 条 串 行 连接 的 环 路 上 ， 所 
以 一 旦 某 个 站 点 出 现 了 故障 ， 整 个 网 络 将 瘫痪 。 并 且 在 这 样 一 个 串 行 
结构 中 ， 要 找到 具体 的 故障 点 非常 困难 ， 必 须 一 个 站 点 一 个 站 点 地 排 
除 ， 非 常 不 便 。 另 一 方面 ， 因 为 同 轴 电 缆 所 采用 的 十 插 针 接触 方式 ， 
也 非常 容易 出 现 接触 不 良 ， 造 成 网 络 中 断 ， 网 络 故障 率 非 常 高 。 笔 者 
束 曾 经 维护 过 这 样 一 个 小 型 企业 网 ， 虽 然 只 有 20 多 台 机 ， 但 因 分 布 在 
几 栋 建筑 物 中 ， 几 乎 天 天 发 生 网 络 故障 ， 有 时 一 查 就 可 能 是 几 个 小 
时 。 


2.3.4 总 线 型 拓扑 结构 


总 线 型 拓扑 结构 (Bus Topology) 与 上 市 介绍 的 环形 拓扑 结构 从 外 
形 上 看 有 些 类 似 ， 都 是 共享 一 条 同 轴 电 缆 作 为 传输 介质 ， 通 过 RPU 
(中 继 转 发 器 ) 连接 多 台 计 算 机 ， 而 且 网 络 通信 中 都 是 以 令 牌 的 方式 
进行 的 。 所 谓 “ 总 线 ? 就 表示 ， 网 络 中 连接 的 各 站 点 间 进 行 数据 通信 时 
都 必须 通过 这 条 线 缆 。 但 总 线 型 拓扑 结构 采用 的 是 IEEE 802.4 标 准 (对 
应 RFC 1230) ， 接 入 速率 也 低 于 上 市 介绍 的 环形 网 络 (只 有 
10Mbps) ， 这 两 种 拓扑 结构 还 是 存在 较 大 不 同 的 ， 具 体 将 在 本 节 后 面 
介绍 。 但 要 说 明 的 是 ， 在 当前 的 局 域 网 中 ， 纯 粹 的 总 线 型 结构 网 络 基 
本 上 不 见 了 ， 取 而 代 之 的 是 在 一 些 特殊 的 网 络 环境 中 与 星 型 拓扑 结构 
混合 使 用 ， 也 就 是 在 本 章 后 面 即 将 介绍 的 混合 型 拓扑 结构 。 


1. 总 线 型 结构 概述 


总 线 型 拓扑 结构 网 络 中 所 有 设备 通过 连接 套 并 行 连接 到 一 条 传输 
电缆 〈 通 常 称 之 为 中 继 线 、 总 线 、 了 母线 或 干线 ) 上， 并 在 两 端 加 装 一 
个 称 为 “ 终 接 絮 ”的 组 件 ， 如 图 2-25 所 示 。 终 接 絮 主要 用 来 与 总 线 进行 阻 
抗 匹配 ， 最 大 限度 吸收 传送 端 部 的 能 量 ， 避 人 免 信 号 反射 回 总 线 产 生 不 
必要 的 干扰 。 


服务 器 儿 


图 2-25 总 线 型 结构 示例 


总 线 型 结构 网 络 所 采用 的 传输 介质 一 般 也 是 同 轴 电 缆 (包括 粗 同 
轴 电 缆 和 细 同 轴 电 缆 ， 也 有 采用 光纤 的 ) ， 如 ATM 了 网 、Cable Modem 所 
采用 的 网 络 等 都 属于 总 线 型 网 络 结构 。 为 了 扩展 所 连接 的 计算 机 数 
量 ， 可 以 在 网 络 中 添加 其 他 的 扩展 设备 ， 如 中 继 嚣 。 图 2-26 所 示 的 整 是 
通过 中 继 器 连接 的 两 个 总 线 型 网 络 单元 。 


， 终 接 器 


图 2-26 双 总 线 结构 网 络 互 连 示 例 


总 线 型 拓扑 结构 的 代表 技术 就 是 IEBM 的 ARCNet 令 牌 网 络 ， 所 以 总 
线 型 拓扑 结构 通常 认为 是 令 牌 总 线 (Token Bus) 结构 。 物 理 上 是 总 线 
网 ， 逻 辑 上 是 令 牌 网 。 总 线 型 拓扑 结构 与 上 万 介 绍 的 环形 拓扑 结构 相 
比 ， 不 同 之 处 主要 体现 在 以 下 两 个 方面 。 


(1) 与 传输 电缆 的 连接 方式 不 同 


环形 拓扑 结构 中 的 连接 器 与 电缆 是 串联 的 ， 所 以 任何 连接 站 点 出 
现 故 障 都 会 引起 整个 网 络 的 中 断 ， 而 总 线 型 拓扑 结构 中 的 连接 如 与 电 


缆 是 并 联 的 ， 所 以 某 个 站 点 发 生 故 障 不 会 影响 网 络 中 的 其 他 站 点 通 
信 。 


(2) 数据 传输 原理 不 同 


两 种 拓扑 结构 的 数据 传输 原理 不 一 样 。 在 总 线 型 拓扑 结构 中 ， 令 
牌 帧 和 数据 帧 都 是 沿 着 根据 当前 网 络 环境 自动 生成 的 逻辑 令 牌 环 进行 
传输 的 ， 而 不 生 像 环 形 拓 扑 结构 那样 按照 物理 环 路 径 进 行 传输 的 。 具 
体 将 在 本 太后 面 介 绍 。 


2. 令 牌 总 线 数据 传输 原理 


IEEE 802.4 标 准 下 的 令 牌 总 线 的 介质 访问 控制 (MAC) 是 根据 局 
域 网 物理 总 线 的 各 站 点 先生 成 一 个 逻辑 环 ， 每 一 个 站 点 都 在 一 个 序列 
中 被 指定 一 个 逻辑 位 置 (注意 ， 不 是 物理 位 置 ) ， 序 列 中 最 后 一 个 站 
点 的 后 面 又 跟着 第 一 个 站 点 ， 以 形成 一 个 逻辑 上 闭合 的 环 上 路。 图 2-27 所 
示 的 就 是 一 个 小 型 总 线 拓扑 型 拓扑 结构 计算 机 网 络 示例 。 从 图 中 可 以 
看 出 ， 在 物理 结构 上 ， 它 是 一 个 总 线 拓扑 结构 局 域 网 ， 但 是 在 逻辑 结 
构 上 ， 义 成 了 一 种 环形 拓扑 结构 的 局 域 网 : 
A-D-C-G-F-B-E-~A。*。 


图 2-27 令 牌 总 线 中 的 站 点 连接 表 


另外 ， 在 总 线 型 拓扑 结构 网 络 中 ， 每 个 站 点 都 知道 在 它 之 前 的 站 
点 和 在 它 之 后 的 邻居 站 点 标识 。 为 了 保证 逻辑 闭合 环 路 的 形成 ， 每 个 
站 点 都 动态 地 维护 着 一 个 连接 表 ， 该 表 记 录 着 本 站 点 在 环 路 中 的 前 
继 、 后 继 和 本 站 点 的 地 址 。 如 图 2-27 所 示 ，A 站 点 中 有 E、D、A 这 三 个 
地 址 ， 分 别 代表 着 A 站 点 的 前 继 站 点 (E 站 点 ) MAC 地 址 、 后 继 站 点 
(D 站 点 ) MAC 地 址 和 本 站 点 MAC 地 址 。 每 个 站 点 根据 它 的 后 继 站 点 
MAC 地 址 确定 下 一 个 可 能 要 占有 令 牌 的 站 点 。 所 以 ， 令 牌 的 传递 顺序 


与 总 线 上 各 站 点 的 物理 位 置 无 大 。 


如 采 总 线 网 络 中 某 个 站 点 出 现 故障 或 没有 工作 ， 则 会 重新 建立 新 
的 逻辑 令 牌 环 网 络 ， 绕 开 出 现 故 障 或 没有 工作 的 站 点 (因为 各 站 点 之 


间 古 并 行 连 授 的 )  ， 如 图 2-28 所 示 的 束 是 图 2-27 所 示 的 忌 线 型 拓扑 结构 
网 络 在 出 现 两 个 站 点 (C 和 G 站 点 ) 没有 正常 工作 时 新 建 的 令 牌 环 网 。 


图 2-28 当 总 线 网 络 中 出 现 不 能 正常 工作 站 点 时 新 建 的 令 牌 环 网 络 


令 脾 总 线 网 络 与 令 牌 环 网 络 的 数据 传输 原理 基本 一 样 ， 部 是 站 所 
在 发 送 数 据 前 必须 和 完 取得 “ 令 脾 ”， 取 得 令 脾 的 站 点 有 数据 帆 要 发 送 则 
可 发 送 ， 如 采 没 有 数据 帧 要 发 送 ， 则 直接 把 令 牌 传递 到 逻辑 令 牌 环 中 
的 后 继 站 点 。 而 且 只 有 获得 令 牌 的 站 点 才能 发 送信 息 ， 其 他 站 点 只 能 
接收 信息 ， 或 者 被 动 地 发 送信 息 〈 在 拥有 令 牌 的 站 点 要 求 下 发 送信 
轧 ) 。 由 于 站 点 接收 到 令 牌 的 过 程 是 顺序 依次 进行 的 ， 因 此 对 所 有 站 
点 都 有 公平 的 访问 权 ， 也 不 会 出 现 介质 访问 神 突 。 


在 具体 的 数据 发 送 过 程 中 ， 取 得 了 令 牌 的 站 点 把 令 牌 帧 和 数据 帧 
一 起 〈 在 此 也 称 之 为 信息 帧 ) 在 总 线 网 络 中 发 送 ， 其 他 各 站 点 均 可 收 
到 这 个 信息 帧 ， 但 也 只 有 其 MAC 地 址 与 接收 到 的 数据 帧 中 的 目的 MAC 
地 址 一 致 的 站 点 才 会 复制 并 接收 该 信息 上 师 ， 把 其 中 的 数据 帆 传 递 给 对 
应 的 站 点 PC (将 其 中 的 令 牌 巅 丢 弃 ) ， 然 后 原来 的 信息 帧 继续 沿 着 逻 
辑 令 牌 环 传递 ， 直 到 回 到 发 送 数 据 的 源 站 点 。 当 发 送 数 据 由 的 站 点 收 
到 接收 数据 帧 的 站 点 的 啊 应 后 束 可 得 知 该 次 数据 发 送 成 功 ， 随 即 释放 
目 己 所 控制 的 令 牌 ， 按 照 逻辑 令 牌 环 的 顺序 把 令 牌 依次 传递 到 它 的 后 
继 站 点 。 


3. 总 线 拓扑 结构 的 主要 优 缺 点 
总 线 拓扑 结构 的 优点 与 环形 拓扑 结构 差不多 ， 主 要 有 如 下 几 点 。 


(1) 网 络 结构 简单 ， 易 于 布线 


因为 总 线 型 网 络 与 环形 网 络 一 样 都 是 共享 传输 介质 ， 也 通常 无 需 
男 外 的 网 络 设备 ， 所 以 整个 网 络 结构 比较 简单 ， 布 线 比较 容易 。 


(2) 扩展 较 容易 


这 是 总 线 型 网 络 相对 同样 是 采用 同 轴 电线 (或 光纤 ) 作为 传输 介 
质 的 环形 网 络 结构 的 最 大 的 一 个 优 后。 因为 总 线 型 结构 网 络 中 ， 各 站 
点 与 总 线 的 连接 是 通过 并 行 连接 (环形 网 络 中 连接 器 与 电 弦 的 连接 是 


捉 行 的 ) 实现 的 ， 所 以 站 点 的 扩展 无 需 断 开 网 络 ， 扩 展 容易 了 许多 。 
而 且 还 可 通过 中 继 设备 扩展 连接 到 其 他 网 络 中 ， 进 一 步 提高 了 可 扩展 
性 能 。 

(3) 维护 容易 

总 线 型 网 络 中 的 连接 器 与 总 线 电 缆 是 并 行 连 接 的 ， 这 给 整个 网 络 
的 维护 市 来 了 极 大 的 便利 ， 因 为 一 个 站 点 的 故障 不 会 影响 其 他 站 点 ， 


更 不 影响 整个 网 络 ， 所 以 故障 点 的 查找 就 容易 了 许多 。 这 与 星 型 拓扑 
结构 类 似 。 


尽管 有 以 上 一 些 优 点 ， 但 是 它 与 环形 拓扑 结构 网 络 一 样 ， 缺 点 仍 
主要 的 ， 这 些 缺 点 也 决定 了 它 在 当前 网 络 应 用 中 也 极 少 使 用 的 命 
运 。 总 线 型 结构 的 主要 缺点 表现 在 以 下 几 个 方面 。 


训 


(1) 传输 速率 低 


IEEE 802.5 令 牌 环 网 中 的 最 高 传输 速率 可 达 16Mbps， 但 IEEE 802.4 
标准 下 的 令 牌 总 线 网 络 标 准 最 高 传输 速率 仅 为 10Mbps。 所 以 它 虽然 在 
扩展 性 方面 较 令 牌 环 网 络 有 一 些 优势 ， 但 它 同样 摆脱 不 了 被 淘汰 的 命 


i 


(2) 故障 诊断 困难 


虽然 总 线 拓扑 结构 简单 、 可 靠 性 高 ， 而 且 是 互 不 影响 的 并 行 连 
接 ， 但 故障 的 检测 仍然 很 不 容易 。 这 坪 因 为 这 种 网 络 不 生 集 中 陈 连 
接 ， 故 障 诊断 需要 在 网 络 中 各 站 点 计算 机 上 分 别 进 行 。 另 外 ， 在 这 种 
结构 中 ， 如 果 故 障 发 生 在 各 个 计算 机 内 部 ， 只 需要 将 计算 机 从 总 线 上 
去 掉 ， 比 较 容 易 实 现 。 但 是 如 果 是 总 线 传 输 介质 发 生 故障 ， 则 需要 更 
换 全 部 相应 段 传输 介质 了 。 


(3) 难以 实现 大 规模 扩展 


虽然 相对 环形 网 络 来 说 ， 总 线 型 网 络 在 扩展 性 方面 有 了 一 定 的 改 
普 ， 可 以 在 不 断 开 网 络 的 情况 下 添加 设备 ， 还 可 添加 中 继 胡 之 类 的 设 
备 了 予以 扩展 ， 但 受到 传输 性 能 的 限制 ， 其 扩展 性 仍然 远 不 如 星 型 网 
络 ， 难 以 实现 大 规模 的 扩展 。 


综 上 所 述 ， 单 纯 总 线 型 结构 网 络 目前 也 已 基本 不 用 ， 因 为 传输 性 
能 太 低 (只 有 10Mbps) ， 可 扩展 性 也 受到 性 能 的 限制 。 目 前 总 线 型 结 
构 就 是 在 后 面 将 要 介绍 的 混合 型 网 络 中 才 会 用 到 的 。 在 这 些 混合 型 网 
络 中 使 用 总 线 型 结构 的 目的 就 是 用 来 连接 两 个 (如 两 栋 建筑 物 ) ， 或 
多 个 (如 多 楼 层 ) 相距 超过 100m 的 局 域 网 ， 细 同 轴 电 缆 连 接 的 距离 可 
达 185m， 粗 同 轴 电 缆 可 达 500m。 如 果 超 过 这 两 个 标准 ， 就 需要 用 到 光 
纤 了 。 但 无 论 采 用 哪 种 传输 介质 的 总 线 型 结构 ， 传 输 速率 都 只 有 
10Mbps， 实 用 性 极 低 ， 还 不 如 直接 采用 光纤 星 型 拓扑 结构 。 


2.3.5 树 形 拓扑 结构 


关于 树 形 拓扑 结构 (Tree Topology) 的 描述 ， 目 前 有 多 种 版 本 ， 有 
的 说 是 忌 线 型 拓扑 结构 的 扩展 ， 有 的 说 是 星 型 拓扑 结构 的 扩展 ， 其 实 
两 者 均 有 道理 。 之 所 以 认为 是 星 型 拓扑 结构 的 扩展 ， 是 因为 其 中 的 每 
个 集 线 设备 (如 交换 机 ) 所 连接 的 就 是 一 个 个 星 型 拓扑 结构 单元 。 之 
所 以 认为 是 忌 线 型 拓扑 结构 的 扩展 ， 是 因为 树 形 拓扑 结构 中 各 设备 间 
是 通过 类 似 的 “总 线 ” (交换 机 级 联 电脑 ) 进行 互 连 的 ， 一 个 星 型 结构 
单元 的 节点 与 另 一 个 星 型 结构 单元 的 节点 之 间 的 通信 都 是 共享 这 


条 “总 线 ” 的 。 一 般 认 为 树 形 拓扑 结构 是 星 型 拓扑 结构 的 扩展 。 


树 形 拓扑 结构 自 上 而 下 (从 核心 交换 机 (或 骨干 层 ) 到 汇聚 层 ， 
再 到 边缘 层 ) 是 自 上 而 下 依次 分 层 扩展 的 ， 就 像 一 棵 倒 放 的 “ 树 ”， 这 
或 许 区 是 把 它 定 义 为 " 树 形 ” 折 扑 结构 的 原因 之 一 吧 。 树 形 折 扑 结构 的 
最 顶层 (也 就 是 核心 层 ， 相 当 于 树 的 “ 根 ”"， 中 间 层 〈 汇 聚 层 ) 相对 
于 “ 树 的 枝 ”， 而 最 下 层 (边缘 层 ， 或 者 接 入 层 ) 则 相当 于 树枝 上 的 “ 细 
极 ” 和 "“ 树 时 ?。 目 上 而 下 ， 所 用 的 交换 机 数量 生 逐 层 增 多 的 。 人 简化 的 树 
形 拓扑 结构 如 图 2-29 所 示 〈 图 中 每 一 个 大 圆圈 代表 一 人 台 区 换 机 ， 最 下 面 
的 每 个 小 圆圈 代表 一 台所 连接 的 主机 ) 。 


大 核心 层 
Ce 熏 党 汇聚 层 


CC CD CD CD CH 接 人 民 
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图 2-29 树 形 拓扑 结构 示意 图 


经 验 之 谈 其实 还 有 许多 类 似 “ 树 ”形状 的 实例 ， 如 各 公司 的 组 织 
结构 也 是 目 上 而 下 依次 展开 的 〈 最 上 面 只 有 董事 长 一 人 ， 下 面 是 各 级 
董事 ， 再 下 面 是 总 经 理 、 部 门 经 理 、 科 室 主 任 等 ) ， 还 有 我 们 所 用 的 
Internet 网 站 域名 也 是 自 上 而 下 展开 的 (分 为 根 域名 、 顶 级 域名 (一 级 
域名 ) 、 二 级 域名 、 三 级 域名 等 ， 如 图 2-30 所 示 ) ， 这 部 分 将 在 第 11 章 
具体 介绍 


顶级 域名 ， 也 称 


Int CO edu gov mil org net en Us jp ee 
-级 域名 
/ 
/ 
- A 
net org bj t 二 级 域名 


yale ac com gov edu g 
ee 
of 
al - 
buaa 三 级 域名 


一 级 域 
-级 域名 CS eng pku nankai tsinghua 


al linda 四 级 域名 


图 2-30 域名 结构 


在 计算 机 网 络 技术 中 ， 还 有 一 种 技术 同样 引用 了 “ 树 ” 的 概念 ， 那 
就 是 将 在 第 6 章 介绍 的 生成 树 协 议 (STP) 。 它 形象 地 利用 了 “ 树 ” 中 树 
根 、 和 树干 、 树 校 、 树 叶 之 间 这 种 无 交叉 的 逻辑 关系， 以 实现 交换 网 络 


中 无 二 层 环 路 。 

图 2-31 所 示 的 束 是 一 个 典型 的 树 形 拓扑 结构 。 它 采用 分 级 的 集中 控 
制 方式 ， 其 传输 介质 可 有 多 条 分 文 ， 但 不 形成 团 合 回路 ， 每 条 通信 线 
路 都 必须 文 持 双 辐 传 输 。 


Ai 核心 交换 机 


服务 器 Tl 服务 器 


一 _ 

用 

%., 
< 


3 So 司 Ex 全 到 -本 y 
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’ 是 王 王 


中 


ee ee 


图 2-31 典型 树 形 拓扑 结构 示例 


从 以 上 介绍 可 以 得 知 ， 树 形 拓 扑 结构 的 主要 优点 还 是 扩展 性 方 
面 。 星 型 拓扑 结构 便于 扩展 我 们 已 经 知道 ， 只 要 在 集 线 设 备 空余 端口 
上 拉 出 一 条 网 线 ， 束 可 以 添加 新 的 设备 ;而 在 树 形 拓扑 结构 中 ， 有 是 通 
过 多 级 星 型 结构 的 级 联 ， 可 以 更 方便 地 实现 在 连接 距离 和 端口 数据 上 
的 扩展 ， 实 现 更 大 规模 网 络 的 扩展 升级 。 


但 树 形 拓扑 结构 目 身 也 有 一 些 不 足 ， 这 主要 体现 在 以 下 两 个 方 
面 : 一 是 对 “ 根 ” 设 备 (核心 ， 或 者 骨干 层 ) 交换 机 的 依赖 性 太 大 ， 如 
果 “ 根 "发生 故障 ， 则 那些 依赖 “ 根 ?设备 访问 的 服务 器 或 外 网 则 全 部 不 可 
访问 了 ， 相 当 于 总 线 型 拓扑 结构 中 总 线 中 断后 ， 所 有 用 户 网 络 都 中 断 
一 样 。 另 外 ， 处 于 最 顶端 的 核心 层 设 备 ， 因 为 下 面 连接 了 更 多 的 级 联 


设备 和 用 户 ， 人 负荷 更 重 ， 需 要 配备 性 能 更 强 的 交换 机 和 路 由 设备 ， 成 
本 比较 高 。 但 这 些 不 足 都 可 以 通过 配置 元 余 链 路 和 选择 高 性 能 设备 来 
弥补 。 树 形 拓扑 结果 是 目前 中 小 型 以 太 局 域 网 (如 位 于 同一 楼 层 ， 或 
者 分 布 于 少数 几 个 楼 层 的 局 域 网 ) 中 最 主要 的 拓扑 结构 。 


2.3.6 ”网 状 拓 扑 结构 


网 状 拓扑 结构 (Mesh Topology) 又 称 无 规则 型 拓扑 结构 。 在 这 种 
结构 中 ， 各 节操 之 间 通 过 传输 介质 彼此 互 连 ， 构 成 一 个 网 状 结构 。 


网 状 拓扑 结构 又 有 “全 网 状 结构 ”和 “ 半 网 状 结构 ”两 种 。 所 谓 “ 全 网 
状 结构 ” 束 是 指 网 络 中 任何 两 个 市 点 间 痢 十 相互 连接 的 。 假 设 一 个 网 络 
中 有 n 个 节点 ， 则 任何 一 个 节点 加 有 n-1 条 与 其 他 和 点 的 连接 。 图 2-32 
所 示 的 吏 是 一 个 全 网 状 拓扑 结构 。 而 所 谓 的 “ 半 网 状 结构 ?是 指 网 络 中 
并 不 是 每 个 市 点 都 与 网 络 的 其 他 所 有 节点 有 连接 ， 可 能 只 是 一 部 分 节 
态 间 有 互 连 ， 如 图 2-33 所 示 ，A 市 点 就 没有 与 E 廊 点 直接 连 授 ，C 市 点 
也 没有 与 FT 点 直接 连接 。 
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图 2-32 全 网 状 拓 扑 结构 示例 


图 。 2-33 半 网 关 拓 扑 结 构 示 例 


从 以 上 介绍 可 以 知道 ， 网 状 拓扑 结构 的 布线 是 相当 复杂 的 (中间 
没有 集中 连接 设备 ， 全 靠 电缆 来 互 连 ) ， 布 线 成 本 也 非常 高 ， 因 为 每 
个 市 点 要 用 多 条 电 绕 与 其 他 市 点 依次 连接 。 同 样 ， 由 于 中 间 没 有 集中 
连接 设备 ， 每 个 万 点 PC 都 需要 安装 多 块 网 卡 ， 当 一 个 节点 要 互 连 的 其 
他 市 点 比较 多 时 ， 这 显然 不 可 行 。 所 以 这 种 网 状 拓扑 结构 在 局 域 网 中 
且 极 少 使 用 的 ， 最 多 也 只 是 极 少数 的 节点 采用 了 半 网 状 拓扑 结构 。 


网 状 拓 扑 结 构 主 要 用 于 广域网 中 ， 这 时 它们 连接 的 不 再 古 终 站 用 
户 PC 点 ， 而 是 网 络 设备 结 点 ， 如 网 络 中 的 交换 机 、 路 由 亚 等 设备 。 
在 广域网 中 采用 网 状 拓扑 结构 可 以 实现 多 个 网 段 ， 或 者 子 网 间 的 彼此 
互 连 。 因 为 交换 机 和 路 由 器 这 些 设备 本 喘 束 具有 多 个 网 络 端口 ， 所 以 
进行 网 状 连接 也 很 镜 单 ， 只 是 需要 多 拉 几 条 线 而 已 。 


广域网 中 采用 网 状 拓扑 结构 的 主要 目的 殉 是 通过 实现 链 路 或 路 由 
线路 的 元 余 ， 提 高 网 络 的 可 靠 性 。 当 然 ， 一 般 并 不 会 在 整个 广域网 中 
而 只 是 在 骨干 网 络 中 采用 这 种 拓扑 结构 。 


图 2-34 所 示 为 一 个 广 域 骨干 网 全 网 状 拓扑 结构 示例 。 示 例 中 各 个 
路 由 硕 之 间 彼 此 互 连 。 但 更 多 的 是 采用 半 网 状 拓扑 结构 ， 仅 少数 绪 点 
需要 与 网 络 中 其 他 所 有 结 点 互 连 。 如 图 2-35 所 示 的 束 是 广 域 骨干 网 中 
采用 半 网 状 拓 扑 结 构 的 一 个 示例 。 示 例 中 各 路 由 絮 只 与 少数 其 他 路 由 
右 互 连 ， 并 不 是 全 部 互 连 。 


一 - 
E ~ 一 rr AS 全 


Router E 


图 2-34 广 域 骨干 网 中 的 全 网 状 拓扑 结构 示例 


Router A 


Router H 


Router G Router C 


Router F Router D' 


Router E 


2-35 广 域 骨干 网 中 的 半 网 状 拓扑 结构 示例 


网 状 拓扑 结构 具有 较 高 的 可 靠 性 ， 因 为 这 种 拓扑 结构 中 各 节点 的 
连接 存在 见 余 线路 ， 任 何 单一 连接 线路 中 断 都 不 会 影响 网 络 的 整体 连 
接 。 同 样 是 由 于 存在 见 余 线路 ， 所 以 比较 容易 在 多 条 线路 上 实现 负载 
均衡 。 但 其 结构 复杂 ， 配 置 也 很 复 洒 ， 实 现 起 来 成 本 可 能 很 高 ， 特 别 
征 在 广域网 环境 ， 也 不 易 管理 、 维 护 和 进行 网 络 扩 展 ; 同样 由 于 节点 
间 存 在 多 条 元 余 线路 ， 导 致 容易 出 现 路 由 环 路 ， 或 者 二 层 环 路 〈 如 果 
连接 的 结 点 是 交换 机 ) ， 路 由 配置 复杂 。 


2.3.7 ”混合 型 拓扑 结构 


混合 型 网 络 结构 是 目前 局 域 网 ， 特 别 是 分 布 型 大 中 型 局 域 网 中 应 
用 最 广泛 的 网 络 拓扑 结构 ， 它 可 以 解决 单一 网 络 拓扑 结构 的 传输 距离 
和 连接 用 户 数 扩展 的 双重 限制 。 


1. 混 合 型 拓扑 结构 概述 


混合 型 网 络 拓扑 结构 是 指 由 多 种 结构 (如 星 型 拓扑 结构 、 环 形 拓 
扑 结构 、 总 线 型 结构 、 网 状 结构 ) 单元 组 成 的 拓扑 结构 ， 但 常见 的 是 
由 星 型 拓扑 结构 和 总 线 型 拓扑 结构 结合 在 一 起 组 成 的 ， 如 图 2-36 所 示 。 


图 2-36 混合 型 拓扑 结构 示例 


混合 型 拓扑 结构 更 能 满足 较 大 网 络 的 灵活 扩展 ， 解 决 星 型 网 络 在 
传输 距离 上 的 局 限 (因为 双 绞 线 的 单 段 最 大 长 度 要 远 小 于 同 轴 电 绕 和 
光纤 ) ， 同 时 又 解决 了 总 线 型 网 络 在 连接 用 户 数量 的 限制 。 图 2-36 所 示 
只 是 一 种 简单 的 混合 型 网 络 结构 ， 实 际 上 的 混合 型 拓扑 结构 主要 应 用 
于 分 布 在 多 层 或 者 多 栋 建 筑 物 中 的 网 络 中 。 其 中 采用 同 轴 电 缆 或 光纤 
的 “总 线 ” 用 于 垂直 或 横 癌 干线 ， 基 本 上 不 连接 工作 站 ， 只 旦 连接 各 楼 
层 或 各 建筑 物 中 各 核心 交换 机 ， 而 其 中 的 星 型 拓扑 结构 网 络 则 体现 在 
各 楼 层 或 各 建筑 物 内 部 的 各 用 户 网 络 中 ， 如 图 2-37 所 示 。 
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图 2-37 多 楼 层 的 混合 型 网 络 结构 示例 


在 实际 的 组 网 中 ， 现 在 一 般 很 少 使 用 同 轴 电缆 作为 总 线 了 ， 而 是 
采用 传输 性 能 更 好 ， 更 方便 进行 网 络 连 接 的 大 对 数 双 绞 线 。 因 为 在 一 
般 的 20 层 以 内 的 楼 中 ，100m 的 双 绞 线 就 可 以 满足 ， 如 图 2-38 所 示 。 
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图 2-38 分 层 星 型 拓扑 结构 示例 


如 果 距 离 过 远 ， 如 高 楼 层 或 多 建筑 物 之 间 的 网 络 互 连 ， 则 可 以 用 
光纤 作为 传输 介质 ， 无 论 哪 一 种 ， 传 输 性 能 均 要 比 总 线 型 连接 方式 好 
许多 。 


2. 混 合 型 拓扑 结构 的 主要 特点 


混合 型 拓扑 结构 主要 有 以 下 几 个 方面 的 特点 。 


(1) 应 用 广泛 


这 主要 是 因 混 合 型 拓扑 结构 解决 了 星 型 和 总 线 型 拓扑 结构 的 不 
足 ， 满 足 了 大 公司 组 网 的 实际 需求 。 目 前 在 一 些 智 能 化 的 信息 大 厦 中 
的 应 用 非常 普 裔 。 在 一 幢 大 厦 中 ， 各 楼 层 间 采用 光纤 作为 忌 线 传输 介 
质 ， 一 方面 可 以 保证 网 络 传输 距离 ， 另 一 方面 ， 光 纤 的 传输 性 能 要 远 
好 于 同 轴 电 统 ， 在 传输 性 能 上 也 给 予 了 充分 人 保证。 当然， 这 不 仅 天 系 
到 传输 介质 的 选择 问题 ， 更 重要 的 是 涉及 网 卡 和 交换 机 妆 口 类 型 的 选 
择 ， 光 纤 类 型 决口 网 卡 和 交换 机 要 贯 许 多 的 。 


(2) 扩展 灵活 


这 主要 是 因为 混合 型 拓扑 结构 继承 了 星 型 拓扑 结构 的 优点 。 但 由 
于 仍 采 用 广播 式 的 消息 传送 方式 ， 因 此 在 总 线 长 度 和 市 点 数量 上 也 会 
受到 限制 ， 不 过 在 局 域 网 中 的 影响 不 是 很 大 。 


(3) 维护 较为 困难 


这 主要 受到 总 线 型 网 络 折 扑 结构 的 制约 ， 如 采 总 线 中 断 ， 则 互 连 
的 各 部 分 网 络 也 就 中 断 了 ， 特 别 是 对 于 那些 使 用 统一 核心 交换 机 的 网 
络 ; 但 是 如 条 是 分 文 网 段 出 了 故障 ， 则 仍 不 影响 整个 网 络 的 正 利 运 
作 。 


2.3.8 ”无 线 局 域 网 的 两 种 拓扑 结构 


在 无 线 局 域 网 (WLAN) 中 有 Ad-Hoc 和 Infrastructure 两 种 拓扑 结 
构 (其 实 可 以 理解 为 WLAN 的 两 种 管理 模式 ) ， 前 者 连接 性 能 较 差 ， 
连接 用 户 较 少 (通常 为 5 个 以 内 ) ， 主 要 用 于 小 型 家 庭 和 SOHO 网 络 
中 ; 后 者 连接 性 能 较 好 ， 主 要 用 于 较 多 用 户 的 企业 网 络 中 ， 应 用 更 为 
这。 


1. 无 线 AP 的 Ad-Hoc 模 式 主要 优 缺 点 


Ad-Hoc 对 等 WLAN 模 式 采用 的 是 点 对 点 连接 方式 (如 图 2-39 所 
示 ) ， 只 能 单 点 通信 ， 就 像 有 线 网 络 中 对 等 网 一 样 ， 所 以 连接 性 能 较 
差 ， 仅 适用 于 较 少 数量 的 计算 机 无 线 互 连 (通常 是 在 5 台 主 机 以 内 ) 。 
同时 由 于 这 一 模式 没有 中 心 管理 单元 ， 因 此 这 种 网 络 在 可 管理 性 和 扩 
展 性 方面 受到 一 定 的 限制 。 而 且 各 无 线 节 点 之 间 只 能 单 点 通信 ， 不 能 
实现 交换 连接 。 当 然 这 一 无 线 网 络 结构 还 是 有 它 自身 优点 的 ， 那 就 是 
网 络 结构 简单 ， 只 要 安装 了 无 线 网 卡 即 可 连接 ， 无 需 其 他 网 络 设备 ， 
成 本 非常 低 。 
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2-39 Ad-Hoc 对 等 无 线 局 域 网 结构 


2. 基 于 无 线 AP 的 Infrastructure 结 构 


这 种 基于 无 线 AP 的 Infrastructure 基 础 结构 模式 其 实 与 有 线 网 络 中 
的 星 型 交换 模式 差不多 (如 图 2-40 所 示 ) ， 除 了 各 无 线 用 户 需要 安装 
无 线 网 卡 外 ， 还 需要 一 个 用 于 集中 连接 各 无 线 用 户 的 无 线 AP， 它 相当 
于 有 线 网 络 中 的 集线器 。 无 线 AP 都 提供 了 一 个 有 线 以 太 网 接口 ， 用 于 
与 有 线 网 络 、 工 作 站 和 路 由 设备 的 连接 。 这 种 网 络 结构 模式 主要 优势 
表现 在 网 络 易于 扩展 、 便 于 集中 管理 、 能 提供 用 户 号 份 验证 等 方面 
上 ， 男 外 数据 传输 性 能 也 明显 高 于 Ad-Hoc 对 等 结构 。 


2-40 Infrastructure 基础 无 线 局 域 网 结构 


其 实 图 2-40 所 示 也 只 是 一 个 Infrastructure 基 础 结构 单元 ， 在 实际 的 
企业 WLAN 网 络 中 ， 可 能 有 许多 台 AP 设 备 ， 而 且 还 可 能 有 WLAN 天 
线 、WLAN 中 继 器 、WLAN 网 桥 、WLAN 控 制 器 等 设备 。WLAN 天 线 
和 WLAN 中 继 需 可 用 于 连接 更 远 距 离 的 WLAN 用 户 ，WLAN 网 桥 可 用 
于 连接 不 同 的 WLAN 网 段 ，WLAN 控 制 器 则 可 对 整个 WLAN 网 络 进行 
管理 。 这 就 涉及 信道 的 分 配 和 优化 了 ， 在 一 定 范 围 内 不 能 有 信道 的 重 


登 ， 否 则 信号 之 间 就 可 能 产生 冲突 。 


有 关 WLAN 的 主要 技术 将 在 第 6 章 具体 介绍 。 


第 3 章 ”计算 机 网 络 体系 结构 


从 本 革 起 就 开始 正式 介绍 计算 机 网 络 体系 结构 (Computer Network 
Architecture) 了 。 本 章 先 从 宏观 角度 介绍 各 种 计算 机 网 络 体系 结构 。 
关 重 旗 析 了 它们 之 间 的 联系 、 数 据 通信 原理 、 各 层 的 数据 传输 单元 、 
各 层 数据 封装 原理 以 及 各 层 主 要 功能 ， 本 书后 面 各 章 将 具体 介绍 这 些 
体系 结构 中 各 层 主要 功能 实现 原理 、 主 要 通信 协议 以 及 相关 的 计算 机 
网 络 基础 知识 。 


计算 机 网 络 体系 结构 是 一 个 分 层次 的 模块 式 结构 ， 这 样 设计 的 目 
的 一 方面 是 便于 我 们 从 安 观 上 把 握 整 个 网 络 体系 架构 ， 实 现 快速 分 析 
与 排除 网 络 故障 ;， 另 一 方面 是 便于 程序 开发 人 员 在 进行 网 络 系统 开发 
时 针对 不 同 网 络 功能 进行 独立 开发 ， 无 须 考 虑 其 他 层 的 功能 。 


在 计算 机 网 络 体系 结构 中 ， 除 了 要 介绍 我 们 最 熟悉 的 第 一 个 标准 
化 的 计算 机 网 络 互 连 体系 结构 OSVRM (Open System Interconnection 
Reference Model， 开 放 系 统 互 连 参 考 模型 ) 外 ， 还 要 介绍 局 域 网 体系 
结构 IEEE 802.1、TCP/IP 协 议 体 系 结构 (虽然 至 今 都 没有 标准 化 ， 但 已 
是 事实 上 的 标准 ， 是 否 标准 化 已 没什么 关系 了 ) 和 无 线 局 域 网 
(WLAN) 体系 结构 的 IEEE 802.11。 以 上 所 列 的 各 种 协议 之 间 ， 在 存 
在 着 一 些 差 异 的 同时 也 有 着 密切 的 关系 ， 事 实 上 后 面 几 个 针对 不 同 计 
算 机 网 络 类 型 的 体系 结构 都 是 参照 或 基于 OSVRM 来 设计 或 者 改进 的 。 


3.1 典型 计算 机 网 络 体系 结构 


通过 对 2.1.2 闻 的 学 习 我 们 已 经 知道 ， 早 在 20 世 纪 60 年 代 末 ， 随 着 
第 二 代 分 组 交换 式 计 算 机 网 络 (杰出 代表 就 是 美国 的 APPANET 网 络 ) 
的 诞生 ， 就 已 出 现 了 计算 机 网 络 体系 结构 的 锥 形 ， 那 就 是 把 整个 计算 
机 网 络 划分 为 “通信 子 网 和 “资源 子 网 >?， 如 图 3-1 所 示 。 随 后 在 第 三 代 
计算 机 网 络 中 ，ISO 推 出 了 第 一 个 标准 化 的 计算 机 网 络 体系 结构 
OSIRM (Open System Interconnection Reference Model， 开 放 系 统 互 连 
参考 模型 ) 。 后 面 又 有 一 些 国际 组 织 或 公司 先后 推出 了 局 域 网 体系 结 
构 IEEE 802.1、TCP/P 协 议 体系 结构 (虽然 至 今 都 没有 标准 化 ， 但 已 是 
事实 上 的 标准 ) 和 无 线 局 域 网 (WLAN) 体系 结构 的 IEEE 802.11。 本 
节 先 来 认识 这 几 种 网 络 体系 结构 及 其 一 些 基 本 而 又 非常 重要 的 原理 。 
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图 3-1 APPANET 的 基本 体系 结构 


3.1.1 OSLRM 体 系 结构 


OSLVRM 体 系 结构 是 第 一 个 标准 化 的 计算 机 网 络 体系 结构 。 它 是 针 
对 广域网 通信 (也 就 是 不 同 网 络 之 间 的 通信 ) 进行 设计 的 ， 将 整个 网 
络 通信 的 功能 划分 为 七 个 层次 ， 由 低 到 高 分 别 是 物理 层 (Physical 
Layer) 、 数 据 链 路 层 (Data Link Layer) 、 网 络 层 (Network 
Layer) 、 传 输 层 (Transport Layer) 、 会 话 层 (Session Layer) 、 表 示 
层 (Presentation Layer) 、 应 用 层 (Application Layer) ， 如 图 3-2 所 
示 。 但 任何 广域网 其 实 都 是 由 多 个 远程 局 域 网 连接 而 成 的 ， 所 以 在 


OSIRM 中 不 仅 包 括 了 广域网 中 不 同 局 域 网 间 通 信 的 功能 层次 (上 面 五 
层 ) ， 也 给 出 了 局 域 网 内 部 通信 所 必需 的 两 个 层次 (最 下 面 两 层 ) 。 


应 用 层 (Application Layer ) 第 七 层 
第 六 层 
第 五 层 


es 
EM 第 四 层 


物理 层 ( Physical Layer ) 第 一 层 


图 3-2 OSVRM 七 层 参考 模型 


OSIRM 低 四 层 (从 物理 层 到 传输 层 ) 定义 了 如 何 进行 端 到 端的 数 
据 传 输 ， 也 就 是 定义 了 如 何 通过 网 卡 、 物 理 电缆 、 区 换 机 和 路 由 需 进 
行 数据 传输 ， 而 高 三 层 (从 会 话 层 到 应 用 层 ) 定义 了 终端 系统 的 应 用 
程序 和 用 户 如 何 彼 此 通信 ， 也 即 定义 了 如 何 重建 从 发 送 方 到 目的 方 的 
应 用 程序 数据 流 。 更 多 的 是 把 OSVRM 的 七 层 结 构 分 成 低 三 层 和 高 四 层 


的 ， 低 三 层 负责 创建 网 络 通信 所 需 的 网 络 连 接 〈 面 向 网 络 ) ， 属 于 “ 通 
信子 网 部分， 高 四 层 具体 负责 端 到 端的 用 户 数据 通信 〈 面 向 用 户 ) ， 
属于 “资源 子 网 ”部 分 。OSIRM 结 构 中 各 层 功 能 如 图 3-3 所 示 。 


应 用 层 一 > 提供 各 种 网 络 应 用 接口 
二 表示 层 一 > 数据 表示 、 压 缩 与 加 密 
宽 源 于 网 

会 话 层 一 > 主机 间 的 会 话 管 理 

传输 层 一 > 端 到 问 的 可 菲 传输 

网 络 层 一 > 寻 址 和 路 由 选择 
通信 子 网 数据 链 路 层 ”| 一 相 邻 节点 间 的 可 徘 传 输 


一 > 二 进 制 比特 流传 输 


图 3-3 OSILRM 各 层 基 本 功能 


经 验 之 谈 在 OSVRM 中 ， 低 三 层 有 两 方面 的 作用 :上 自 先 是 通过 它 
们 目 己 对 应 层 的 信息 交换 构建 数据 通信 所 需 的 网 络 平台 ， 更 通 从 地 说 
束 是 打通 一 条 用 于 数据 传输 的 网 络 通道 ;然后 吏 是 为 来 目 上 层 的 数据 
提供 物理 的 传输 通道 。 但 低 三 层 均 不 能 识别 和 处 理 来 目 应 用 层 的 网 络 
应 用 数据 ， 仅 用 于 为 用 户 的 网 络 应 用 数据 通信 提供 通信 线路 、 网 络 基 
础 架构 ， 或 者 说 是 网 络 通信 平台 。 高 四 层 上 进行 的 才 是 真正 面向 用 户 


的 网 络 应 用 ， 为 各 种 具体 的 网 络 应 用 提供 应 用 平台 和 端 对 端的 数据 传 
输 通道 ， 对 低 三 层 所 构建 的 网 络 平台 可 以 说 是 “视而不见 ”。 


我 们 经 常 听 别人 说 ， 在 局 域 网 中 仅 可 以 通过 数据 链 路 层 的 MAC 地 
址 进行 通信 ， 很 多 人 就 认为 网 络 应 用 也 可 以 仅 可 以 通过 数据 链 路 层 进 
行 。 其 实 这 是 完全 错误 的 。 这 里 所 说 的 “通信 ”其 实 是 仅 指 两 层 设备 之 
间 的 “网 络 通信 ”， 用 于 构建 数据 通信 所 需 的 链 路 。 它 根本 不 能 识别 网 
络 应 用 的 用 户 数据 〈 这 涉及 数据 的 封装 次 序 ， 具 体 将 在 本 章 后 面 介 
绍 ) ， 怎 么 可 能 进行 网 络 应 用 通信 ? 在 局 域 网 中 进行 具体 的 网 络 应 用 
仍 需要 用 到 OSIRM 的 网 络 层 及 以 上 各 层 ， 只 是 这 些 高 层 是 由 用 户主 机 
的 操作 系统 来 完成 的 。 


无 论 是 哪 种 划分 方式 ，OSIRM 的 每 一 层 都 要 完成 特定 的 功能 ， 每 
层 都 直接 为 它 的 上 层 提供 服务 ， 同 时 又 调用 它 的 下 层 所 提供 的 服务 。 
所 有 层次 都 互相 支持 ， 在 发 送 端 网 络 通 信和 是 自 上 而 下 进行 的 (也 就 是 
自 上 而 下 调用 服务 ， 在 接收 端 网 络 通信 和 是 自 下 而 上 (也 就 是 自 下 而 
上 提供 服务 ) 进行 的 ， 但 双方 必须 在 对 等 层次 上 进行 通信 (这 就 是 对 
等 通信 原理 ， 具 体 将 在 本 章 后 面 介 绍 ) 。 当 然 并 不 是 每 一 通信 都 需要 
经 过 OSI 的 全 部 七 层 ， 要 视 具 体 通 信 的 类 型 而 定 ， 有 的 甚至 只 需要 双方 
对 应 的 某 一 层 即 可 。 如 物理 层 中 的 物理 接口 之 间 的 转 接 ， 以 及 中 继 器 
与 中 继 器 之 间 的 连接 就 只 需 在 物理 层 中 进行 即 可 。 而 网 络 层 中 的 路 由 
器 与 路 由 器 之 间 连 接 则 只 需 经 过 自 网 络 层 以 下 的 三 层 即 可 。 


经 验 之 谈 “无论 哪 一 种 计算 机 网 络 体系 结构 ， 也 无 论 是 体系 结构 
中 的 哪 一 层 ， 都 不 是 针对 具体 的 设备 或 者 具体 的 软件 而 言 的 ， 而 只 是 
针对 每 层 中 所 要 实现 的 网 络 服务 功能 来 划分 的 。 因 为 每 一 层 所 代表 的 
征 一 组 网 络 功能 ， 而 实现 某 一 个 功能 又 可 以 有 许多 不 同 的 软 /硬件 方 
和 案 。 如 物理 层 上 残 可 以 有 许多 不 同 的 传输 介质 (如 同 轴 电 统 、 双 绞 
线 、 光 纤 等 ) 和 网 络 设备 (如 集线器 、 中 继 器 ) ， 当 然 还 有 许多 对 应 
的 通信 协议 。 其 他 各 层 也 一 样 。 计 算 机 网 络 中 的 软 /硬件 是 计算 机 网 络 
通信 和 数据 传输 的 实体 ， 也 就 是 网 络 任务 的 具体 执行 者 。 当 然 各 层 的 
实体 都 不 一 样 ， 具 体 将 在 后 面 对 应 章 世 介绍 。 


有 了 这 样 一 个 结构 模型 ， 就 把 整个 计算 机 网 络 软 、 人 硬件 技术 和 设 
备 串 起 起 来 了 ， 所 有 软 、 硬 件 技术 都 围绕 在 这 个 中 心 周 围 。OSIRM 对 
各 个 层次 的 划分 遵循 下 列 原则 : 


口 同一 层 中 的 各 网 络 丰 点 都 有 相同 的 层次 结构 ， 具 有 同样 的 功 


口 同一 节点 内 相 邻 层 之 间 通 过 接口 (可 以 是 逻辑 接口 ) 进行 通 


口 七 层 结构 中 的 每 一 层 使 用 下 一 层 提供 的 服务 ， 并 向 其 上 层 提供 


服务 。 


口 不 同 节 点 的 同等 层 按 照 协议 实现 对 等 层 之 间 的 通信 。 


口 网 络 设备 〈 不 包括 计算 机 主机 ) 间 自 身 的 通信 仅 需要 低 三 层 ， 
用 来 构建 数据 通信 的 网 络 平台 。 网 络 平台 构建 好 后 ， 用 户 应 用 数据 就 
可 以 利用 这 个 平台 进行 各 种 网 络 应 用 通信 ， 但 所 有 网 络 应 用 通信 都 需 
要 经 过 网 络 体系 结构 中 的 所 有 层次 ， 其 中 最 上 面 的 四 层 用 来 为 用 户 的 
网 络 应 用 通信 提供 各 种 服务 支持 ， 构 建 数据 通信 平台 。 


但 是 OSURM 的 七 层 结构 划分 从 现在 看 来 ， 并 不 是 很 科学 ， 这 主要 
表现 在 两 方面 : 一 是 层次 数 方面 还 是 多 了 些 ; 二 是 在 进行 网 络 系统 设 
计时 仍然 觉得 比较 麻烦 。 另 外 ， 像 “会 话 层 "和 ”表示 层 ” 单 独 划 分 的 意义 
并 不 大 ， 因 为 它们 的 用 途 并 不 像 其 他 层 那 样 明显 。 所 以 在 后 面 的 
TCP/P 协 议 体系 结构 中 ， 不 再 有 这 两 层 了 。 


3.1.2 ”TCP/IP 协 议 体 系 结构 


TCP/IP 协 议 体系 结构 (又 称 TCP/IP 协 议 参 考 模型 是 专门 针对 使 
用 TCP/IP 协 议 簇 的 广 域 计算 机 网 络 而 开发 的 ， 可 以 说 是 OSVRM 的 改进 
版 本 。 但 绝 不 能 简单 地 认为 是 改进 版 ， 因 为 它 与 OSVRM 所 针对 的 网 络 
类 型 存在 较 大 区 别 ， 所 以 这 两 种 体系 结构 中 各 层 所 采用 的 通信 协议 ， 
以 及 功能 实现 原理 上 都 存在 非常 大 的 差异 。 这 一 点 ， 在 后 面 章节 中 都 
会 有 相应 的 体现 。 现 在 我 们 常用 的 通信 协议 ， 绝 大 多 数 都 不 是 很 适用 
于 OSVRM， 而 是 适用 于 TCP/IP 协 议 体 系 结构 ， 因 为 它们 都 是 应 用 于 
TCP/IP 网 络 中 。 


TCP/IP 协 议 体系 结构 起 源 于 20 世 纪 60 年 代 末 ， 首 先 由 美国 国防 部 
高 级 研究 规划 署 (Defense Advanced Research Projects Agency， 
DARPA) 作为 其 研究 的 一 部 分 ， 所 以 又 称 DARPA 参 考 模型 。 不 仅 广 域 
网 鼻祖 ARPANET 使 用 的 是 TCP/P 协 议 体系 结构 ， 现 在 使 用 最 广 的 
Internet 也 是 基于 这 一 模型 设计 的 ， 因 为 目前 的 Internet 基 本 上 都 是 采用 
TCP/IP 协 议 簇 的 ， 包 括 我 们 企业 内 部 局 域 网 。 


TCP/IP 协 议 体 系 结构 只 划分 了 四 层 ， 从 高 到 低 分 别 是 :应 用 层 
(Apllication Layer) 、 传 输 层 (Transport Layer) 、 网 际 互 连 层 
(Internet Layer， 义 称 互联 网 层 ) 和 网 络 访问 层 (Network Access 

Layer， 义 称 网 络 接 入 层 、 网 络 接口 层 或 者 主机 -网 络 层 ) 。 虽 然 只 有 四 


层 ， 但 它 却 包 含 了 OSIURM 中 的 所 有 七 层 的 功能 ， 同 样 包括 了 局 域 网 和 
广域网 通信 所 需要 的 全 部 功能 。 图 3-4 描 绘 了 TCP/IP 协 议 体 系 结构 与 
OSIRM 层 次 间 的 关系 。 


OSIRM TCP/IP 协 议 体系 结构 


应 用 层 


应 用 层 


网 际 互 连 层 


数据 链 路 层 


物理 层 


图 3-4 TCP/IP 协 议 体 系 结构 及 与 OSVRM 的 比较 


网 络 访问 层 


从 图 中 可 以 看 出 ， 在 TCP/IP 协 议 体 系 结构 中 对 原来 OSVRM 的 七 层 
结构 进行 了 进一步 的 简化 ， 主 要 体现 在 以 下 两 个 方面 : 


口 把 原来 的 “物理 层 ” 和 “数据 链 路 层 ” 这 两 层 结构 合并 为 一 层 ， 即 网 
络 访问 层 ， 它 提供 局 域 网 中 的 功能 ; 


口 合并 了 原来 OSUVRM 中 的 最 高 的 三 层 ， 成 为 新 的 应 用 层 。 因 为 事 
实 上， 在 OSIHRM 中 会 话 层 和 表示 层 的 功能 都 非常 单一 ， 完 全 可 以 合并 
到 应 用 层 之 中 名 


其 他 两 层 , “传输 层 " 与 OSVRM 中 的 功能 划分 是 一 样 的 ， 而 网 际 互 
连 层 也 与 OSURM 的 网 络 层 实 际 上 是 一 样 的 ， 只 不 过 名 称 不 一 样 而 已 。 
但 要 注意 的 是 ， 这 里 仅 是 从 功能 划分 上 来 说 的 ， 实 际 上 这 两 个 体系 结 
构 是 存在 相当 大 差异 的 。 因 为 OSUVRM 是 开放 型 的 标准 ， 所 以 适用 于 所 
有 类 型 网 络 设计 参考 ， 而 TCP/IP 协 议 体 系 结构 是 专门 针对 TCP/P 网 络 
的 ， 各 种 通信 协议 和 功能 实现 原理 更 加 具体 。 


总 体 而 言 ，TCP/IP 协 议 体系 结构 更 加 精简 ， 更 有 利于 网 络 系统 的 
设计 。 但 是 其 中 网 络 访问 层 本 号 并 不 是 实际 的 一 层 ， 包 括 了 OSIRM 中 
的 物理 层 和 数据 链 路 层 这 两 层 的 功能 ， 现 在 把 它们 其 实 合 并 不 是 很 合 
理 ， 所 以 现在 通常 认为 如 图 3-5 (其 中 与 标准 的 TCP/IP 协 议 四 层 模 型 和 
OSIRM 七 层 模型 进行 了 对 比 ) 所 示 的 五 层 网 络 体系 结构 才 是 最 为 科 
学 、 合 理 的 。 因 为 它 综合 了 OSIRM 和 TCP/IP 协 议 两 种 体系 结构 的 优 
点 ， 同 时 克服 了 这 两 种 体系 结构 的 不 足 。 本 书 也 将 以 这 种 目前 广泛 建 
议 的 五 层 体 系 结构 进行 介绍 。 
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图 3-5 广泛 建议 的 五 层 网 络 体系 结构 


3.1.3 ”局 域 网 体系 结构 


目前 计算 机 局 域 网 标准 主要 是 由 IEEE 发 布 的 ， 所 以 局 域 网 体系 结 
构 也 是 由 IEEE 发 布 的 。 它 针对 有 线 以 太 网 和 WLAN 无 线 局 域 网 分 别 发 
布 了 体系 结构 ， 但 IEEE 也 是 参考 了 OSVRM 体 系 结构 来 设计 局 域 网 体系 
结构 的 ， 可 以 说 是 OSUVRM 体 系 结构 中 专门 描述 局 域 网 通信 的 最 低 两 
层 ， 或 者 TCP/PP 协 议 体 系 结构 中 专门 描述 局 域 网 通信 的 最 下 面 一 层 ， 
针对 以 太 网 所 进行 的 细 化 。 当 然 其 实 这 两 种 局 域 网 体系 结构 从 层次 上 
来 说 是 一 样 的 ， 不 同 的 只 是 其 中 各 层 的 功能 实现 方法 和 所 适用 的 通信 
协议 不 同 。 


1. 有 线 以 太 局 域 网 体系 结构 


有 线 以 太 局 域 网 体系 结构 是 在 IEEE 802.1A 标 准 中 定义 的 ， 如 图 3-6 
所 示 。 从 图 中 可 以 看 出 ， 它 仅 包 括 了 OSIRM 的 最 低 两 层 (物理 层 和 数 
据 链 路 层 ) ， 因 为 局 域 网 内 部 的 通信 只 需要 这 两 层 。 


OSVRM 


网 络 层 


局 域 网 体系 结构 


数据 链 路 层 | 数据 链 路 层 


物理 层 


图 3-6 IEEE 802.1A 有 线 局 域 网 体系 结构 


本 节 前 面 介 绍 的 OSURM 和 TCP/P 协 议 体 系 结构 可 以 说 都 是 针 广 域 
网 设计 的 ， 并 不 是 局 域 网 通信 所 全 部 需要 的 ， 这 具体 表现 在 两 个 方 
面 : 在 局 域 网 中 不 需要 路 由 寻 址 ， 所 以 也 就 不 需要 它们 的 网 络 层 ， 
或 者 说 网 际 互 连 层 ; 人 传输 层 和 应 用 层 的 功能 是 通过 安装 在 计算 机 操 
作 系 统 中 的 网 络 通信 协议 和 一 些 具体 网 络 应 用 软件 来 实现 的 ， 所 以 在 
局 域 网 设备 中 也 不 需要 这 两 层 。 


男 外 ， 又 因为 局 域 网 (如 以 太 网 ) 通常 是 属于 广播 型 网 络 ， 存 在 
介质 争 用 现象 (广域网 中 通常 是 属于 点 对 点 网 络 ， 通 肖 不 存在 介质 争 
用 ) ， 所 以 它 在 OSVRM 划 分 的 物理 层 和 数据 链 路 层 中 又 进一步 对 数据 


链 路 层 进 行 了 细 分 ， 将 其 分 成 了 两 个 子 层 ， 即 介质 访问 控制 (Media 
Access Control，MAC) 子 层 和 逻辑 链 路 控制 (Logical Link Control， 

LLC) 子 层 。 其 中 的 MAC 子 层 就 主要 是 用 来 解决 介质 争 用 和 局 域 网 内 
部 寻 址 的 。 


IEEE 802.1A 局 域 网 体系 结构 中 的 物理 层 与 OSIURM 和 TCP/P 协 议 体 
系 结构 中 的 物理 层 功 能 是 一 样 的 ， 但 仅 文 持 IEEE 802 系 列 局 域 网 标准 
(如 IEEE 802.3 系 列 、IEEE 802.4、IEEE 802.5) 中 的 物理 层 协议 
MAC 于 层 则 主要 是 文 持 IEEE 802 系 列 局 域 网 标准 中 的 载波 监听 多 路 访 
问 (Carrier Sense Multiple Access，CSMA) 、 载 波 监听 多 路 访问 / 神 突 


今 测 (Carrier Sense Multiple Access/Collision Detect，CSMA/CD) 协 
议 ， 以 及 把 物理 层 的 比特 流 封 装 成 MAC 子 帧 的 功能 ，LLC 子 层 主 要 文 
持 IEEE 802 系 列 局 域 网 标准 中 的 LLC 子 帧 封装 、 链 路 控制 和 管理 功能 。 


这 些 都 将 在 第 6 章 具体 介绍 ， 在 此 不 再 著述 。 
2.WLAN 体 系 结构 


WLAN 也 是 局 域 网 的 一 种 ， 所 以 WLAN 体 系 结构 与 上 面 介绍 的 
IEEE 802.1A 局 域 网 体系 结构 是 完全 一 样 的 (如 图 3-6 所 示 ) ， 只 不 过 因 
为 两 种 局 域 网 所 用 的 物理 层 传输 介质 ， 以 及 相关 数据 链 路 层 技 术 或 协 
议 不 一 样 ， 所 以 在 WLAN 体 系 结构 中 的 这 两 层 中 所 包括 的 内 容 也 不 一 
样 ， 具 体 如 图 3-7 所 示 。 有 关 的 具体 标准 和 技术 将 在 第 6 章 介 绍 。 


| 


WLAN QoS 及 安全 相关 标准 
LLC 子 层 ee 
( 包括 IEEE 802.11e、IEEE 802.11i 等 标准 ) 
WLAN MAC 访 问 控 制 (CSMA/CA ) 、 数 据 加 /解密 、PCF 
MAC 子 层 控制 数据 加 / 解 


(点 对 点 协调 ) 和 DCF (分布 式 协调 ) 等 功能 


+ 


WLAN 接 入 标准 ( 包括 IEEE 802.11、IEEE 802.11b、 
物理 层 
IEEE 802.11a、 IEEE 802.11g、IEEE 802.11n 等 ) 


一 


图 3-7 WLAN 体 系 结构 中 所 文 持 的 协议 和 标准 


3.1.4 例 说 网 络 体系 结构 各 层 主 要 功能 


本 市 将 以 最 常见 的 生活 事例 来 诠释 OSVRM 计 算 机 网 络 体系 结构 中 
各 层 的 基本 功能 (其 他 体系 结构 对 应 层次 的 功能 类 似 ， 参 照 即 可 ) ， 
以 便 能 使 读者 更 加 容易 理解 。 当 然 或 许 里 面 有 些 比 喻 并 不 是 很 贴切 ， 
但 只 要 对 理解 这 些 层次 的 功能 有 所 帮助 就 达到 目的 了 。 


1. 物 理 层 


物理 层 站 OSURM 以 及 其 他 所 有 计算 机 网 络 体系 结构 的 最 克 层 ， 为 
所 有 网 络 /数据 通信 提供 物理 的 通信 线路 。 物 理 层 是 用 来 构建 计算 机 网 
络 通信 和 数据 传输 的 通道 的 ， 相 当 于 日 向 交通 网 络 中 的 各 种 道路 ， 如 
公路 、 铁 路 和 航线 ， 它 们 是 我 们 出 门 旅行 必须 要 依 徘 的 基础 设施 。 但 
物理 层 不 是 针对 具体 的 传输 介质 、 设 备 和 通信 协议 的 ， 因 为 它们 可 以 
有 许多 种 选择 (如 传输 介质 中 就 可 以 有 同 轴 电 统 、 双 绞 线 和 光纤 
等 ) ， 只 要 能 实现 物理 层 的 某 种 功能 就 行 了 。 


不 同 的 传输 介质 和 设备 选择 ， 必 须要 有 对 应 的 通信 协议 支持 ， 而 
且 这 也 决定 了 不 同 的 选择 有 不 同 的 物理 层 性 能 。 残 像 路 有 好 多 种 一 
样 ， 如 有 泥巴 路 、 沙 子路 、 水 泥 路 、 柏 油 马路 、 普 通 铁路 、 高 速 铁路 
等 ， 这 些 不 同 的 路 可 以 承载 的 重量 和 速率 都 不 一 样 。 不 同 的 路 相连 束 


形成 了 我 们 旅行 途经 的 整 条 路 径 ， 同 样 ， 计 算 机 网 络 中 的 不 同 物理 层 
相连 也 构成 了 双方 通信 的 整 条 路 径 。 


男 外 ， 我 们 知道 在 各 种 道路 中 都 会 划分 许多 车 道 的 ， 在 计算 机 网 
络 体系 结构 中 也 有 类 似 的 “车 道 ”， 那 就 古 我 们 通常 所 说 的 “信道 ”。 信 道 
的 全 称 束 是 “信号 传输 通道 "， 默 认 情 况 下 ， 一 条 物理 线路 束 是 一 条 信 
道 ， 但 也 可 以 通过 各 种 信道 复 用 方式 在 一 条 物理 线路 中 划分 出 多 条 信 


道 。 有 关 信道 复 用 方式 将 在 第 4 章 介绍 。 


2. 数 据 链 路 层 


数据 链 路 层 为 同一 局 域 网 内 部 的 网 络 /数据 通信 提供 点 对 点 的 数据 
传输 通道 ， 通 过 MAC 地 址 寻 址 把 数据 转 到 目的 万 点 ， 可 以 理解 为 我 们 
的 市 内 公路 + 交通 法 规 。 之 所 以 只 能 理解 为 市 内 公路 ， 是 因为 在 各 个 网 
络 中 的 数据 链 路 层 间 的 通信 仪 可 以 在 同一 网 段 内 进行 ， 之 所 以 还 要 加 
上 “交通 法 规 ”， 是 因为 数据 链 路 层 所 提供 的 不 再 是 物理 线路 ， 而 是 在 
物理 层 的 物理 线路 基础 之 上 ， 通 过 数据 链 路 层 协议 (相当 于 市 内 交通 
法 规 ) 构建 的 ， 可 真正 用 于 数据 传输 的 虚拟 数据 传输 通道 ， 但 这 样 的 
虚拟 数据 传输 通道 也 只 能 在 同一 网 段 内 进行 数据 加 发 。 数 据 链 路 层 仅 
为 所 到 达 数 据 在 本 网 段 内 进行 转发 提供 传输 通道 ， 要 在 不 同 网 段 间 进 
行 数据 转发 ， 还 必须 依靠 下 面 将 要 介绍 的 网 络 层 和 传输 层 。 


注意 “” 链 路 可 分 为 物理 链 路 和 逻辑 链 路 。 物 理 链 路 可 以 看 成 是 在 
物理 层 中 相 邻 结 点 间 的 那 段 线 路 ， 而 数据 链 路 则 在 物理 链 路 基础 上 再 
封 狠 上 对 应 的 数据 链 路 层 通 信 协 议 ， 是 可 以 实现 数据 传输 的 逻辑 链 
路 。 


3. 网 络 层 或 网 际 互联 层 


OSWRM 中 的 网 络 层 〈 或 TCP/P 协 议 体系 结构 中 的 “网 际 互 连 层 ”) 
为 不 同 网 段 之 间 的 数据 转发 提供 路 径 选 择 ， 通 过 IP 地 址 (也 可 以 是 其 
他 网 络 层 地 址 ， 要 视 具 体 网 络 类 型 而 定 ) 把 数据 包 转 发 到 目的 节点 ， 
可 以 理解 为 交通 网 络 中 的 车 站 、 机 场 、 码 头 。 这 涉及 一 个 选择 下 一 站 
路 径 的 问题 ， 也 就 相当 于 我 们 要 到 某 外 地 去 旅行 ， 到 了 和 车站、 机场 、 
码头 后 要 选择 乘坐 哪 趟 车 、 哪 趟 飞机 或 轮船 才能 最 快捷 ， 成 本 最 低 。 


网 络 层 的 这 种 寻 址 功能 束 是 我 们 通 沼 所 说 的 “路 由 寻 址 ”， 束 十 这 
择 哪 条 路 径 来 到 达 下 一 个 路 由 绪 点 。 通 过 不 同 的 路 径 进 行路 由 ， 在 性 
能 、 成 本 上 都 可 能 不 一 样 ， 束 像 我 们 选择 不 同 的 交通 工具 ， 或 者 不 同 
线路 旅行 时 的 效率 和 成 本 部 不 同一 样 。 网 络 层 的 功能 束 相 当 于 连接 不 
同 网 络 的 桥梁 ， 仅 起 到 在 不 同 网 络 则 转发 数据 包 的 作用 ， 最 终 数 据 还 
征 要 在 目的 网 络 的 数据 链 路 层 进行 传输 ， 在 到 达 下 一 个 网 络 结 点 设备 
(如 路 由 器 ) 时 再 进行 路 由 、 转 发 。 


男 外 ， 束 像 我 们 到 达 男 外 一 个 城市 义 得 遵照 男 外 城市 的 交通 法 规 
一 样 ， 当 我 们 的 通信 和 包 人 a 到达 为 一 个 网 络 时 ， 同 时 要 这 照 这 个 网 络 中 的 
链 路 规则 ， 也 需要 有 相应 的 链 路 层 协 议 来 支持 ， 以 最 终 完成 数据 的 传 


输 。 


4. 传 输 层 


“传输 层 " 是 在 下 面 三 层 构建 的 网 络 平台 基础 上 专门 为 通信 双方 构 
建 端 对 端 (不 是 点 对 点 ) 的 数据 传输 通道 ， 使 通信 双方 束 像 直接 进行 
数据 传输 一 样 。 这 个 端 对 妆 传 输 通 道 是 可 以 跨 网 络 的 ， 这 与 数据 链 路 
层 所 构建 的 仅 用 于 局 域 网 内 部 的 点 对 点 传输 通道 是 不 同 的 。 


传输 层 类 似 于 国际 航线 ， 一 条 国际 航线 可 能 要 经 过 几 个 国家 ， 但 
国际 航班 飞机 飞行 时 根本 不 用 考虑 经 过 了 哪些 国家 的 航线 ， 因 为 这 些 
事先 在 确立 国际 航线 时 束 已 处 理 好 了 ， 就 像 一 条 传输 通道 要 经 过 几 个 
网 络 不 用 管 一 样 ， 因 为 网 络 层 事先 已 准备 好 了 通信 路 径 。 


6. 会 傅 夺 和 表示 届 


这 两 层 仅 在 OSVRM 中 单独 划分 ， 而 在 TCP/IP 协 议 体系 结 构 中 是 没 
有 这 两 层 的 ， 那 是 因为 TCP/IP 协 议 是 专门 针对 TCP/IP 协 议 类 型 网 络 而 
开发 的 体系 结构 ， 不 存在 其 他 网 络 类 型 ， 所 以 不 需要 表示 层 ， 会 话 层 
的 作用 因为 太 单 一 ， 所 以 合并 到 了 应 用 层 中 。 


会 话 层 为 具体 的 用 户 应 用 建立 会 话 进程 (每 个 应 用 都 有 一 个 会 话 
进程 ) ， 这 个 过 程 是 一 个 用 户 网 络 应 用 的 协商 过 程 ， 相 当 于 车 站 、 机 
场 或 码头 中 总 调度 人 员 所 从 事 的 调度 工作 。 


表示 层 是 对 用 户 网 络 应 用 数据 的 具体 解释 ， 包 括 在 网 络 通信 时 可 
采用 的 信息 格式 、 可 采用 的 加 密 方式 ， 相 当 于 车 站 、 机 场 、 码 头 中 发 
送 每 一 班次 汽车 、 火 车 、 轮 船 的 具体 文件 ， 包 括 所 采用 的 车 型 、 机 
型 、 船 型 ， 以 及 所 人 负责 的 运输 公司 、 交 接 人 员 名 单 等 内 容 。 


6. 应 用 层 


应 用 层 是 用 户 进 行 具体 网 络 应 用 的 层次 ， 有 是 具体 网 络 应 用 的 体现 
者 。 应 用 层 负责 接受 用 户 的 各 种 网 络 应 用 进程 的 调用 ， 相 当 于 车 站 、 
机 场 和 码头 的 负责 人 负责 接受 乘客 运输 的 调度 ， 确 定 具 体 班 次 的 发 送 
时 间 和 要 完成 的 任务 。 负 贡 人 一 声 令 下 ， 下 面 的 所 有 相关 工作 人 员 都 
得 围绕 他 的 指令 进行 准备 。 应 用 层 也 一 样 ， 只 要 网 络 用 户 有 和 需要 ， 通 
过 相应 的 网 络 应 用 软件 就 可 以 发 出 相应 的 指令 ， 然 后 通过 应 用 层 相关 
的 通信 协议 来 接收 ， 并 向 它 的 下 面 各 层 依 次 传达 并 使 其 执行 具体 的 网 
络 应 用 指令 ， 进 而 完成 整个 网 络 应 用 任务 。 


OSVRM 七 层 结构 各 层 的 主要 功能 如 表 3-1 所 示 。 


表 3-1 OSI/RM 各 层 主 要 功能 
主要 功能 
* 规定 网 络 设备 的 机 械 特性 和 电气 特性 ， 为 网 络 /数据 通信 提供 物理 连接 和 传输 通道 
* 为 数据 信号 进行 编码 ， 提 供 比特 流 的 透明 传输 


* 建立 网 络 和 数据 通信 的 逻辑 传输 通道 ， 使 有 差错 的 物理 线路 变 成 无 差错 的 数据 链 路 
* 为 同一 网 络 内 部 通信 提供 两 层 MAC 地 址 寻 址 及 帧 格式 封装 
， 以 帧 为 基本 格式 对 数据 提供 流量 控制 和 差错 控制 


* 为 不 同 网 络 间 的 主机 通信 提供 网 络 寻 址 和 路 由 转发 

* 以 分 组 为 基本 格式 提供 流量 控制 、 拥 塞 控制 和 差错 控制 

“以 端 到 端 方式 建立 数据 传输 连接 和 通道 ， 屏 蔽 途经 网 络 中 所 有 低层 服务 上 的 差异 
“以 数据 段 为 基本 格式 提供 流量 控制 、 拥 塞 控制 和 差错 控制 

* 维护 通信 双方 应 用 进程 会 话 

* 管理 通信 双方 数据 交换 进程 

“数据 格式 转换 

* 数据 加 密 与 解密 

* 数据 压缩 与 解压 缩 


为 各 种 网 络 应 用 提供 服务 


3.1.5 OSVRM 和 TCP/IP 协 议 体 系 结构 的 比较 


TCP/IP 协 议 体系 结构 是 在 OSRM 基 础 上 ， 专 门 针 对 TCP/IP 网 络 而 
开发 的 体系 结构 ， 所 以 它 既 有 OSIRM 的 基本 模型 结构 和 层次 划分 思 
想 ， 又 针对 了 特定 的 TCP/IP 了 网络， 所 以 其 更 加 具体 化 ， 更 加 具有 可 操 
作 性 。 本 市 要 具体 介绍 这 两 种 体系 结构 的 主要 异同 。 


1. 相 同 之 处 


总 体 而 言 ，OSVRM 和 TCP/IP 协 议 体 系 结构 主要 具有 以 下 几 个 方面 
的 相同 或 相似 点 : 


(1) 层次 结构 划分 思想 相同 


这 两 种 体系 结构 都 是 以 协议 栈 〈 不 同 协议 形成 的 层次 结构 ) 为 基 
础 进行 层次 结构 划分 的 ， 并 且 协 议 栈 中 的 协议 是 彼此 独立 的 。 这 样 做 
的 好 处 是 ， 可 以 大 大 简化 各 种 网 络 协 议程 序 的 设计 ， 只 需要 为 不 同 协 
议程 序 提供 关联 的 程序 接口 即 可 。 


(2) 总 体 层 次 结构 相似 


在 这 两 个 体系 结构 中 ， 虽 然 尽 的 层 数 和 对 应 层次 名 称 剖 有 所 不 
同 ， 但 总 体 层次 结构 还 是 极其 相似 的 。TCP/AP 协 议 体系 结构 中 的 “网 络 


访问 层 ? 对 应 了 OSIRM 最 低 的 “数据 链 路 层 " 和 “物理 层 ”" 这 两 层 ， 
TCP/P 协 议 体 系 结构 中 的 “应 用 层 ? 对 应 了 OSIRM 最 高 的 “会 话 

层 ”\“ 表 示 层 ”和 “应 用 层 ” 这 三 层 ，OSIRM 中 间 的 “网 络 层 ”虽然 与 
TCP/IP 协 议 体 系 结构 中 的 “网 际 互 连 层 ” 在 名 称 上 不 一 样 ， 但 功能 却 是 
完全 一 样 的 ， 至 于 “传输 层 ”， 则 两 种 结构 都 是 完全 一 样 的 。 而 且 在 这 
两 种 结构 中 , “传输 层 ” 以 下 都 属于 “通信 子 网 * 部 分， 用 来 构建 通信 网 
络 ; 而 “传输 层 ” 及 以 上 各 层 都 提供 了 端 到 端的 、 与 网 络 无 关 的 服务 ， 
属于 “资源 子 网 ”部 分 。 


(3) 核心 组 成 一 样 


这 两 种 体系 结构 中 都 定义 了 “服务 *”、“ 接 口 *? 和 “协议 ”三 个 重要 核 


“服务 ”也 束 是 后 面 各 章 所 说 的 "服务 原 语 >， 定 义 了 各 层 应 该 做 些 
什么 ， 要 提供 哪些 功能 ， 但 没有 定义 本 层 该 如 何 工 作 ， 以 及 上 一 层 该 
如 何 访问 本 层 。 


“接口 ”也 就 是 后 面 各 章 所 说 的 SAP (服务 访问 点 ) ， 为 对 应 的 上 
层 提供 了 获取 本 层 服 务 的 逻辑 接口 ， 规 定 了 有 哪些 参数 可 以 使 用 ， 以 
及 使 用 这 些 参数 的 结果 是 什么 。 


“协议 ”也 殊 是 标准 中 所 说 的 “通信 规程 "， 它 是 各 层 服务 功能 的 具 
体 实现 者 。 当 然 同一 服务 在 不 同 网 络 中 可 以 用 不 同 的 协议 来 实现 。 各 


层 中 的 协议 各 目 实现 目 己 的 功能 ， 并 不 影响 其 他 层 ， 任 何 的 一 层 都 只 
为 相 邻 的 上 一 层 提供 服务 。 


2. 不 同 之 处 


在 看 到 OSIRM 和 TCP/P 协 议 体系 结构 的 相似 之 处 的 同时 ， 也 要 看 
到 这 两 种 体系 结构 的 许多 不 同 之 处 。 两 者 的 不 同 之 处 主要 表现 在 : 


(1) 适用 范围 不 同 


OSVRM 在 标准 化 协议 发 明之 前 就 已 产生 了 ， 所 以 OSVRM 不 偏重 
于 任何 特定 的 网 络 类 型 ， 具 有 最 广泛 的 理论 上 的 参考 性 ， 是 一 个 理想 
化 的 模型 。 而 TCP/IP 协 议 体 系 结构 则 相反 ， 它 是 在 TCP/IP 协 议 簇 先 出 
来 了 (而且 仅 适用 于 TCP/IP 类 型 网 络 ) 后 ， 再 针对 这 些 协 议 进 行 功能 
分 层 和 描述 的 ， 所 以 与 协议 的 关系 非常 紧密 ， 两 者 的 吻合 得 非常 好 ， 
最 具 实 践 性 。 


(2) 层次 结构 不 同 


这 两 种 网 络 体系 结构 在 层次 划分 上 的 不 同 主 要 体现 在 : TCP/IP 协 
议 体系 结 构 中 没有 “会 话 层 ”和 “表示 层 ”， 因 为 事实 已 证 明 这 两 个 层次 
并 没有 多 大 用 途 ， 即 使 在 OSVRM 中 也 一 样 ， 所 以 最 后 取消 了 ， 它 们 的 
功能 合并 在 “应 用 层 ” 之 中 。 


另外 ，OSIRM 中 的 “物理 层 "? 和 “数据 链 路 层 ” 的 功能 在 TCP/PP 协 议 
体系 结构 中 合并 到 了 “网 络 访问 层 ” 中 ， 尽 管 实际 上 在 TCP/IP 协 议 体系 
结构 中 对 这 个 层 中 的 具体 功能 并 没有 明确 规定 ， 但 实际 上 这 层 功 能 就 
是 OSVRM 最 低 的 这 两 层 的 功能 。 当 然 ， 这 也 是 大 家 普遍 认为 TCP/IP 协 
议 体 系 结构 层次 划分 中 不 科学 的 一 个 重要 方面 。 


(3) 支持 的 网 络 通信 模式 不 同 


OSIRM 的 网 络 层 同时 文 持 无 连接 和 面向 连接 的 网 络 通信 〈 它 不 仅 
文 持 TCP/IP 协 议 网 络 中 无 连接 的 IP 网 络 协议 ， 同 时 支持 NetWare 
SPX/IPX 了 网 络 中 的 面向 连接 的 SPX 服 务 等 ) ; TCP/IP 模 型 的 网 络 层 只 
提供 无 连接 的 服务 (因为 它 只 支持 IP 这 种 无 连接 的 网 络 层 协 议 ) 。 


(4) 所 包括 的 通信 协议 不 同 


OSVRM 是 一 种 开放 型 的 ， 希望 尽 可 能 适用 于 所 有 类 型 计算 机 网 络 
的 理想 化 体系 结构 模型 ， 所 以 它 里 面 所 包括 的 通信 协议 不 仅 非 常 多 ， 
且 类 型 非常 复杂 ， 适 用 于 各 类 网 络 的 都 有 。 但 是 ， 由 于 现在 网 络 系统 
设计 者 通常 不 是 参考 OSURM， 而 是 以 目前 占据 了 绝 大 部 分 市 场 的 
TCP/IP 体 系 结构 作为 体系 结构 设计 参考 ， 所 以 现在 OSVRM 中 的 许多 通 
信 协 议 都 已 过 时 。 尽 管 TCP/IP 网 络 也 在 OSVRM 的 设计 范围 内 ， 但 现在 
TCP/IP 网 络 中 的 通信 协议 是 专门 针对 具体 的 TCP/IP 协 议 体系 结构 而 开 


发 的 ， 所 以 更 具有 TCP/IP 协 议 体 系 结构 的 特点 ， 而 且 这 些 通信 协议 在 
不 断 改 进 ， 非 常 适 用 于 目前 广泛 应 用 的 TCP/IP 网 络 。 


3.2 计算 机 网 络 体系 结构 通信 原理 


无 论 是 以 上 哪 种 计算 机 网 络 体系 结构 ， 在 通信 原理 上 它们 都 有 着 
两 个 相同 的 方面 :一 个 是 在 网 络 连接 和 数据 传输 流程 方面， 发送 闹 是 
和 目 上 而 下 (也 就 是 从 高 层 到 低层 ) ， 接 收 端 是 目下 而 上 〈 也 就 是 从 低 
层 到 高 层 ) 进行 的 ， 也 就 是 数据 通信 原理 相同 。 另 一 个 是 通信 会 话 方 
面 ， 双 方 都 作 须 是 逻辑 上 的 对 等 层次 ， 也 就 是 对 等 通信 原理 相同 。 如 
发 送 端的 网 络 层 只 能 与 接收 端的 网 络 层 通信 ， 而 不 能 直接 与 数据 链 路 
层 或 者 与 传输 层 进行 多 错 通 信 。 其 他 的 层次 也 是 一 样 的 。 下 面 分 别 予 


以 介绍 。 


3.2.1 ”网 络 体系 结构 的 数据 通信 原理 


在 各 种 计算 机 网 络 体系 结构 的 网 络 连 接 建 立 和 数据 传输 的 流程 
中 ， 发 送 端 是 把 通信 连接 建立 指令 和 用 户 应 用 数据 从 上 层 回 下层 传输 
的 ， 直 到 最 低 的 物理 层 ;而 接收 端 是 把 通信 连接 建立 指令 和 用 户 应 用 
数据 从 下 层 《从 最 低 的 物理 层 开始 ) 同上 层 传输 的 ， 直 到 与 发 送 端 发 
起 通信 的 对 等 层 。 图 3-8 所 示 的 是 OSVRM 情 形 下 数据 的 传输 流程 ， 其 他 
体系 结构 的 数据 传输 流程 与 此 类 似 ， 只 是 数据 传输 中 流 经 的 层次 上 有 
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图 3-8 OSIRM 数 据 通 信 原 理 示意 图 


其 实 这 也 很 好 理解 ， 毕 竟 网 络 通信 连接 和 数据 传输 都 不 能 皂 空 建 
立 或 进行 。 它 必须 通过 计算 机 网 络 中 最 基础 、 也 是 网 络 体系 结构 中 的 
最 低层 一 一 物理 层 ， 通 过 传输 介质 来 传递 各 种 通信 连接 建立 信号 和 数 
据 。 但 在 进行 具体 的 数据 传输 前 ， 必 须 移 建立 好 相应 的 连接 。 建 立 的 
连接 可 以 是 永久 连接 (如 局 域 网 中 的 连接 和 广域网 中 的 各 种 专线 连 
接 ) ， 也 可 以 是 非 永久 连接 〈《 如 各 种 拨号 连接 和 串 行 线路 ) 。 就 像 我 
们 上 互联 网 都 要 拨号 连接 (专线 连接 的 除外 ) ， 打 电话 我 们 首先 也 要 
拨号 一 样 。 再 如 ， 当 我 们 要 运输 货物 到 外 地 ， 首 爷 得 找 好 运输 货物 的 
路 径 ， 联 系 好 接收 货物 的 人 ， 在 对 方 确 认可 以 收 货 后 才 可 以 发 货 ， 否 
则 路 都 不 知道 怎么 走 ， 对 方 都 不 想 要 这 批 货物 ， 怎 么 能 发 货 呢 ? 


计算 机 网 络 体 系 结构 中 的 这 种 源 端 目 上 而 下 ， 目 的 端 目 下 而 上 的 
通信 连接 建立 和 数据 传输 流程 ， 与 我 们 在 公司 中 安排 、 完 成 一 个 具体 
任务 的 流程 是 一 样 的 。 


现 假设 A 公司 的 总 经 理 要 与 B 公 司 的 总 经 理 签 个 协议 ， 一般 是 按照 
按 如 下 流程 进行 的 : 


1) A 公司 总 经 理 把 这 个 要 求 向 他 的 某 下 级 部 门 经 理 交 代 ; 


2) 该 部 门 经 理 又 会 把 这 项 具体 的 任务 交代 他 下 面 的 某 个 负责 这 方 
面 工作 的 员工 ， 让 其 做 好 相应 准备 ; 


3) 具体 负责 的 员工 与 对 方 公司 取 得 联系 。 


B 公 司 的 执行 流程 与 A 公司 的 正好 相反 ， 因 为 这 个 任务 请 求 最 和 完 十 
由 B 公 司 下 面 负 贡 具体 联系 工作 的 员工 收 到 的 。 在 他 接收 到 A 公司 的 这 
个 请 求 后 ， 会 向 他 的 直接 上 级 部 门 经 理 反 映 ， 再 后 这 个 部 门 经 理 又 会 
把 这 个 请 求 同 B 公 司 总 经 理 反 映 。B 公 司 的 总 经 理 还 可 能 要 根据 具体 的 
工作 任务 安排 具体 的 签 协 议 日 程 ， 然 后 把 这 些 信 息 依 次 向 下 反馈 到 公 
司 中 具体 负责 这 方面 的 工作 人 员 ， 再 与 A 公 司 的 具体 工作 人 员 沟通 ，A 
公司 人 员 接 到 B 公 司 的 这 些 信息 后 ， 义 要 依次 同上 传达 到 A 公司 的 尽 经 
理 。 在 这 个 流程 中 可 能 要 经 过 多 次 反复 ， 最 终 完 成 A 公司 尽 经 理 与 B 公 
司 总 经 理 整 个 签 协 议事 件 的 信息 下 达 (在 A 公司 ) 、 上 传 (在 B 公 司 ) 


任务 。 接 下 来 的 事 ， 融 是 两 家 公司 总 经 理 之 间 的 事 了 ， 剩 下 的 事 丈 相 
当 于 本 节 后 面 要 介绍 的 通信 会 话 原理 。 


3.2.2 ”网 络 体系 结构 的 对 等 通信 和 上 原理 


通信 双方 的 网 络 连接 建立 好 后 ， 束 可 以 进行 各 种 具体 的 网 络 应 用 
和 网 络 通信 了 ， 但 这 时 的 通信 是 建立 在 双方 对 等 层次 上 的 ， 也 就 是 我 
们 通常 所 说 的 “对 等 层 ” (peer layers) 通信 和 原理。 进行 对 等 通信 主要 出 
于 两 方面 的 考虑 : 一 方面 是 因为 只 有 双方 是 对 等 层次 的 会 话 才 可 能 使 
用 相同 类 型 的 协议 ， 彼 此 才能 “ 听 得 全 ”， 才 能 有 “共同 语言 "， 另 一 方面 
征 因 为 在 网 络 体系 结构 中 ， 每 一 层 都 是 独立 完成 自己 工作 的 ， 其 他 层 
都 是 不 干预 ， 不 了 解 的 。 如 一 方 的 物理 层 只 能 与 对 方 的 物理 层 直 接 通 
信 ， 不 可 能 直接 跳 到 与 对 方 的 “数据 链 路 层 ” 或 其 他 层 进行 对 话 。 同 
理 ， 一方 的 网 络 层 只 能 与 对 方 的 网 络 层 通信 ， 一 方 的 传输 层 只 能 与 对 
方 的 传输 层 通 信 ， 以 此 类 推 。 只 有 “物理 层 ” 之 间 的 会 话 才 是 直接 的 ， 
其 他 各 层 之 间 的 会 话 都 是 逻辑 意义 上 的 ， 如 图 3-9 所 示 (注意 其 中 的 虚 
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图 3-9 ”OSVRM 对 等 通信 原理 示意 图 


注意 ”尽管 必须 遵守 对 等 通信 和 原理， 但 最 终 的 数据 通信 流程 还 是 
要 经 过 发 起 会 话 通信 的 层次 的 下 面 所 的 其 他 层次 的 ， 只 不 过 ， 在 具体 
的 通信 过 程 中 ， 对 于 用 户 来 说 ， 下 面 各 层 是 透明 的 ， 在 网 络 连接 建立 
好 后 ， 我 们 并 不 需要 了 解 下 面 各 层 的 工作 情况 。 所 以 我 们 在 进行 具体 
的 网 络 应 用 (如 文件 传输 ) 时 ， 似 乎 是 直接 把 文件 传 给 了 对 方 。 


(1) 各 层 上 传输 的 数据 格式 


对 等 层 之 间 传 送 的 数据 单位 称 为 PDDU (Protocol Data Unit， 协 议 数 
据 单元 ) 。 不 同 层 的 PDU 所 包括 的 内 容 和 格式 也 不 一 样 。 这 就 要 涉及 
各 层 传输 的 数据 格式 问题 了 。 


在 各 种 网 络 体系 结构 中 的 每 一 层 传输 的 数据 格式 ， 或 者 说 协议 数 
据 单元 (PDU) 是 不 一 样 的 ， 具 体 如 下 ; 


咒 “ 物 理 层 ” 是 以 最 原始 的 “比特 ” (bit) 流 格式 传输 的 ， 或 者 说 物理 
层 的 PDU 束 是 “比特 ”。 


口 “数据 链 路 层 * 的 传输 单位 是 “ 帧 ” (frame) ， 一 个 帧 包括 多 个 比 
符 ， 但 一 个 帧 的 大 小 必须 是 一 个 整数 子 市 。 不 同 协议 的 帧 大 小 也 不 一 
样 。 一 个 帧 其 实 也 就 是 一 个 DPDU (数据 链 路 协议 数据 单元 ) 。 


口 “网 络 层 ” 的 传输 单位 是 “分 组 ” (或 者 “ 包 ”，paket) ， 一 个 分 组 又 
可 以 包括 多 个 巾 ， 分 组 大 小 也 要 根据 不 同 协议 而 定 ， 一 个 分 组 其 实 也 
就 是 一 个 NPDU (网 络 协 议 数据 单元 ) ; 


口传 输 层 比较 特殊 ，OSIRM 体 系 结构 中 是 直接 以 TPDU (传输 协 
议 数据 单元 ) 为 单位 的 ， 而 在 TPC/IP 协 议 体系 结构 中 ，TCP 是 以 数据 段 
(segment) 为 单位 进行 传输 的 ，UDP 是 以 数据 报 (datagram) 为 单位 
进行 传输 的 。 


口 在 会 话 屋 、 表 示 层 和 应 用 层 中 是 以 具体 的 数据 报 文 为 单位 进行 
传输 的 。 


以 上 各 层 的 数据 传输 单位 如 图 3-9 所 示 。 如 果 是 其 他 网 络 体系 结构 
(如 TCP/IP 协 议 体系 结构 、 局 域 网 体系 结构 ) ， 各 层 上 传输 的 数据 格 
式 也 是 一 样 的 ， 不 同 的 只 是 少 了 一 些 层次 而 已 。 


(2) 协议 头 和 协议 尾 的 封装 


在 整个 数据 传输 过 程 中 ， 数 据 在 发 送 端 时 经 过 各 层 时 都 要 附加 上 
相应 层 的 协议 关 和 协议 尾 〈 仅 数据 链 路 层 需要 封装 < 协议 尾 ") 部 分 ， 
也 束 旦 要 对 数据 进行 协议 封闭 ， 以 标识 对 应 层 所 用 的 通信 协议 。 


“协议 头 ” 是 用 来 封装 本 层 PDU 的 , “协议 尾 ” 则 代表 本 层 封装 的 结 
束 。 如 在 我 们 常见 的 以 太 局 域 网 中 传输 的 帧 都 会 封 效 对 应 的 数据 链 路 
层 一 一 以 太 网 协议 ， 其 中 就 包括 MAC 子 层 协 议 尖 和 LLC 子 层 协 议 头 ， 
具体 将 在 第 6 章 介 绍 。 图 3-10 中 左边 箭头 所 示 的 顺序 就 是 OSURM 各 层 的 
数据 封 痛 流 程 ， 其 中 的 AH 为 应 用 层 协议 头 ，PH 为 表示 层 协 议 头 ，SH 
为 会 话 协议 头 ，TH 为 传输 层 协议 头 ，NH 为 网 络 层 协 议 头 ，DH 为 数据 
链 路 层 协议 头 (物理 层 为 最 低层 ， 传 输 的 是 最 小 单位 的 bit (比特 ) ， 
不 需要 再 进行 封装 ， 所 以 没有 “物理 层 头 ”% ，DT 为 数据 链 路 层 协 议 
尾 o 


在 数据 的 接收 端 ， 数 据 是 由 低层 癌 高 层 传输 的 ， 这 样 当 数据 到 达 
某 一 层 后 ， 就 会 去 掉 对 应 下 层 的 协议 头 和 协议 尾部 分 ， 这 个 过 程 承 是 
一 个 解 封 于 的 过 程 ， 征 前 面 协议 封 猴 的 地 过 程 ， 如 岁 3-10 中 石 边 荫 头 所 
示 的 顺序 。 因 为 上 层 并 不 需要 了 解 它 的 下 层 服 务 ， 所 以 当 包 或 帧 送 到 
某 一 层 时 就 会 把 用 来 标识 它 下 一 层 的 协议 尖 和 协议 尾 去 掉 ， 还 原 该 包 
或 帧 在 发 送 端 对 应 层 时 的 包 或 帧 内 容 。 其 实 加 上 协议 类 的 作用 可 以 理 
解 为 在 发 送 端 要 一 层 层 地 加 上 一 个 指明 到 达 下 层 地 址 的 信封 ， 而 在 接 
收 问 则 要 一 层 层 地 拆 开 信封 ， 以 获取 向 上 层 传输 的 地 址 信息 ， 使 数据 
能 继续 同上 层 传输 。 


数据 发 送 端 
应 用 层 


数据 链 路 层 | ! 
比特 流 物理 层 


图 3-10 OSIRM 各 层 数 据 封装 流程 


TCP/P 体 系 结构 中 的 数据 封装 和 通信 原理 与 OSURM 类 似 ， 只 不 过 
没有 OSVRM 这 么 多 层次 。 图 3-11 所 示 的 是 两 个 中 间隔 了 两 个 网 段 的 主 


机 (Ha 和 Hb) ， 在 TCP/IP 网 络 中 的 基本 通信 流程 〈 注 意 箭 头 的 方向 ， 
假设 通信 是 由 Ha 主机 发 起 的 ) 。 


| Router 1 | 
Router 2 6 = 
Host A \ Host B 
NET1 4 


NET3 1 


应 用 层 


Ha A 
< 4 /zx 


网 络 访问 局 | 


Netl 


图 3-11 TCP/IP 网 络 中 的 数据 通信 流程 示例 


总 体 来 说 ， 在 各 计算 机 网 络 体系 结构 的 基本 通信 过 程 中 ， 数 据 在 

发 送 咒 是 目 上 而 下 传输 的 ， 而 在 接收 器 是 目下 而 上 传输 的 ， 整 个 通信 

过 程 必须 依次 经 过 通信 发 起 层 及 以 下 各 层 ， 且 不 能 跨越 。 但 是 各 层 只 
能 与 对 方 的 对 应 层 进行 通信 ， 不 能 出 现 错位 。 


3.3 网络 体 系 结构 的 设计 考虑 


无 论 哪 种 网 络 体系 结构 ， 在 设计 时 都 不 是 随意 的 ， 而 是 经 过 无 数 
专家 学 者 充分 认证 和 鹿 导 考虑 得 出 的 。 我 们 只 有 在 理解 了 设计 者 的 设 
计 思 想 后 ， 才 能 更 好 地 理解 并 在 实际 的 网 络 系统 设计 、 网 络 故 隐 排除 


中 应 用 这 些 设计 思想 。 
3.3.1 网 络 体系 结构 中 的 层次 划分 依据 


“网 络 体系 结构 ”是 一 种 概念 上 的 蓝图 ， 描 述 了 整个 网 络 的 层次 结 
构 和 基本 的 数据 通信 和 规则。 实际 上 残 是 接 述 了 整个 网 络 中 两 个 节操 间 
实现 有 效 通信 的 所 有 过 程 ， 然 后 将 这 些 过 程 划 分 为 逻辑 上 的 组 ， 而 这 
些 组 就 是 网 络 体系 结构 中 所 说 的 “ 层 ”。 


1. 网 络 体系 结构 的 设计 考虑 


网 络 体系 结构 设计 时 的 考虑 其 实 与 一 个 公司 在 设计 组 织 架 构 时 要 
考虑 整个 公司 的 生产 、 经 营 流程 应 该 怎样 更 有 效 是 一 样 的 〈 图 3-12 所 示 
的 是 一 家 小 型 生产 企业 的 典型 组 织 架 构 ) 。 在 为 新 公司 设计 组 织 架 构 
时 首先 会 考虑 这 家 公司 的 经 营 性 质 ， 在 经 营 过 程 中 要 完成 哪些 任务 ， 
而 这 些 任务 应 该 由 谁 来 完成 ， 按 什么 顺序 完成 。 这 里 的 “ 谁 ” 不 是 指 具 
体 的 人 ， 而 古 后 面 要 设计 的 各 个 职能 部 门 。 这 里 的 部 门 就 相当 于 我 们 


所 讲 的 网 络 体系 结构 中 的 “ 层 ”。 在 公司 中 ， 为 了 保证 工作 的 顺利 进 

行 ， 每 个 部 门 内 部 的 员工 自然 是 紧密 配合 相互 协调 的 ， 但 任何 一 个 间 
门 都 不 可 完全 独立 地 工作 ， 因 为 它们 只 是 整个 公司 组 织 的 一 部 分 ， 必 
须要 与 其 他 部 门 协同 工作 。 所 以 各 部 门 都 要 有 负责 与 上 、 下 级 部 门 之 
间 沟 通 的 负责 人 ， 这 殉 相 当 于 网 络 体系 结构 中 的 层 与 层 之 间 相 互通 信 
的 逻辑 接口 ， 称 之 为 SAP (访问 服务 点 ) 。 


总 经 理 


市 场 部 [ 程 部 


图 3-12 典型 生产 型 企业 的 组 织 架 构 示例 


既然 计算 机 网 络 体系 结构 是 分 层 的 ， 那 么 不 同 层次 之 间 必 定 有 一 
个 高 低 之 分 。 注 意 ， 这 里 所 讲 的 层次 高 低 并 不 是 从 管理 角度 来 理解 
的 ， 可 以 说 是 仅 从 通信 流程 ， 或 者 说 是 服务 调用 关系 上 来 划分 的 ， 主 


要 是 “ 谁 移 谁 后 ”的 问题 。 就 像 在 设计 公司 组 织 架 构 时 要 考虑 命令 上 

传 、 下 达 执 行 部 门 的 先后 次 序 一 样 。 在 各 种 计算 机 网 络 体系 结构 中 ， 
不 同 层 次 之 间 并 不 存在 管理 与 被 管理 ， 只 有 通信 流程 角度 上 的 先后 次 
序 ， 当 然 下 层 是 为 上 层 服务 的 。 这 就 与 工厂 生产 流水 线 的 各 个 工作 岗 
位 只 有 先后 次 序 之 分 ， 没 有 管理 与 被 管理 之 分 的 道理 是 一 样 的 。 


2. 网 络 体系 结构 中 的 层次 划分 


为 什么 要 划分 层次 ?其 实 原因 很 商 单 的 ， 束 是 想 把 一 个 难以 实现 的 
复杂 问题 分 解 成 多 个 容易 实现 的 小 问题 。 这 在 我 们 学 习 时 也 一 样 ， 要 
真正 把 计算 机 网 络 专业 学 好 不 是 件 商 单 的 事 ， 要 学 的 知识 和 技能 
多 ， 涉 及 面 太 广 。 如 采 没 有 一 个 全 局 的 观念 ， 不 采取 分 模块 学 习 方 
法 ， 和 是 很 难 学 得 系统 、 学 得 全 面 的 。 学 习 时 ， 如 采 我 们 把 要 学 的 知识 
和 技能 分 成 一 个 个 比较 小 的 模块 ， 然 后 采取 “个 个 击破 ”的 方式 进行 学 
习 ， 殊 可 以 比较 快 地 全 面 掌 握 计 算 机 网 络 专 业 所 需 学 习 的 知识 和 技 


台 巴 


有 ° 


OSVRM 是 第 一 个 标准 化 的 计算 机 网 络 体系 结构 ， 划 分 了 七 个 层 
次 ; 随后 IEEE 又 在 其 颁布 的 IEEE 802.1 标 准 中 发 布 了 专门 针对 局 域 网 的 
体系 结构 ， 也 有 专门 针对 无 线 局 域 网 (WLAN) 而 发 布 的 IEEE 802.11 
标准 又 定义 了 WLAN 的 体系 结构 ， 它 们 都 只 划分 了 两 个 层次 ， 而 最 开 
始 应 用 于 ARPANET， 随 后 成 为 事实 上 的 当前 Internet 体 系 结构 标准 的 
TCP/IP 协 议 体 系 结构 划分 了 四 个 层次 。 这 些 不 同 网 络 体系 结构 的 具体 


层次 将 在 本 章 后 面具 体 介 绍 ， 但 由 此 仍然 可 以 看 出 ， 不 同 网 络 体系 结 
构 所 包含 的 层 数 不 一 样 ， 这 主要 是 因为 在 不 同 网 络 中 实现 网 络 通信 所 
需要 的 功能 不 一 样 。 但 无 论 是 哪 种 体系 结构 ， 都 直接 或 间接 地 包括 了 
最 低 的 两 个 层次 ， 那 吏 是 “物理 层 ” 和 “数据 链 路 层 "， 因 为 这 是 所 有 网 络 
通信 的 基石 和 物理 通道 。 这 些 体系 结构 中 的 具体 层次 将 在 本 章 后 面具 


体 介绍 。 


当然 ， 在 这 里 不 得 不 强调 的 一 点 束 和 证 ， 这 些 网 络 体系 结构 中 的 层 
次 划分 不 是 随意 的 ， 而 是 经 过 科学 家 严格 的 认证 ， 经 过 深思 熟 虚 后 得 
出 的 。 那 么 这 些 网 络 结构 中 的 层次 是 依据 什么 来 划分 的 呢 ? 主要 还 是 
针对 不 同 网 络 环 境 中 ， 用 户 双 方 进行 网 络 通信 的 流程 ， 或 者 通信 和 原理 
来 对 不 同 网 络 功 能 进行 分 层 的 ， 殊 像 把 一 个 产品 的 生产 流水 线 划 分 为 
多 个 工序 一 样 。 另 外 ， 体 系 结构 中 的 层次 划分 还 要 考虑 到 通信 效率 和 
可 行 性 等 诸多 因素 ， 既 要 使 得 整个 网 络 体系 结构 尽 可 能 人 简单， 又 要 确 
保 各 层 的 功能 和 不 同 层次 之 间 的 协商 容易 实现 。 如 生产 一 个 比较 简单 
的 产品 (如 组 装 一 人 台 小 风 遍 ) ， 它 既 可 以 只 设 一 个 工序 ， 由 一 人 来 完 
成 所 有 的 工作 ， 又 可 以 细 化 分 成 两 个 ， 甚 至 更 多 工序 来 协同 完成 。 这 
吕 需 要 综合 考虑 生产 效率 和 生产 成 本 等 多 个 方面 因素 了 。 太 粗 了 会 影 
响 生产 效率 (毕竟 一 个 人 做 的 速度 有 限 ) ， 太 细 了 不 仅 生产 成 本 会 大 
大 增加 〈 人 工 和 设备 费用 比较 高 ) ， 也 会 影响 生产 效率 (浪费 在 中 间 
等 和 产品 生产 流程 上 的 时 间 比 较 多 ) 。 网 络 体系 结构 层次 的 划分 也 是 
一 样 o 


局 域 网 体系 结构 和 WLAN 体 系 结构 都 是 专门 针对 局 域 网 内 部 的 网 
络 通信 来 设计 的 。 而 用 户 的 具体 网 络 应 用 所 需 的 网 络 层 及 以 上 各 层 功 
能 ， 完 全 可 以 直接 通过 局 域 网 内 部 的 用 户主 机 操作 系统 来 实现 ， 所 以 
也 残 只 有 “物理 层 " 和 “数据 链 路 层 ” 这 两 层 了 。 而 OSURM 和 TCP/P 协 议 
体系 结构 都 是 针对 不 同 网 络 之 间 的 互 连 和 通信 而 开发 的 ， 中 间 会 有 许 
多 网 络 层 或 以 上 各 层 设 备 ， 所 以 它们 不 可 能 只 有 物理 层 和 数据 链 路 
层 ， 还 得 考虑 网 络 地 址 的 寻 址 〈 也 就 是 网 络 层 ) ， 考 虑 在 不 同 计算 机 
网 络 中 如 何 建 立 通 信 连 接 和 数据 传输 通道 《也 融 是 传输 层 ， 以 及 
OSIRM 中 的 会 话 层 和 表示 层 ) ， 以 及 基于 网 络 地 址 的 各 种 网 络 应 用 
(应 用 层 ) 。 


3. 主 机 中 所 包含 的 层次 功能 


说 到 这 里 ， 可 能 马上 有 读者 会 本， 难道 在 局 域 网 内 部 惑 没 有 网 络 
应 用 ， 不 需要 进行 数据 传输 ， 不 能 使 用 耳 地 址 这 类 三 层 功 能 吗 ? 当然 
不 是 的 ， 因 为 进行 网 络 应 用 和 数据 传输 是 任何 计算 机 网 络 (当然 也 包 
括 局 域 网 ) 的 最 基本 用 途 ， 人 否则 计算 机 网 络 吏 没 有 价值 了 。 其 实 这 里 
我 们 要 充分 认识 局 域 网 中 各 计算 机 的 角色 了 。 


现在 计算 机 中 安装 的 操作 系统 都 是 网 络 操作 系统 ， 都 具有 网 络 功 
能 ， 可 以 提供 OSIRM 体 系 结构 中 的 各 层 功 能 。 尽 管 局 域 网 中 的 主机 者 
在 同一 网 段 中 ， 无 须 < 网 络 层 ?的 路 由 文 持 ， 但 是 计算 机 中 的 操作 系统 
仍然 支持 “网 络 层 ”中 的 IP 地 址 标识 。 而 且 事 实 上 ， 两 个 远程 网 络 间 的 通 


信 ， 中 间 提 供 网 络 连接 的 设备 〈 如 路 由 器 设备 ) 都 只 文 持 OSURM 体 系 
结构 的 下 三 层 ， 高 四 层 功 能 基本 都 是 由 各 计算 机 提供 的 ， 如 图 3-13 所 


人 小， 


图 3-13 “主机 层 ? 所 处 的 位 置 示例 


3.3.2 ”网 络 体系 结构 分 层 的 好 处 


我 们 已 经 知道 ， 网 络 体系 结构 十 分 层 的 (但 要 注意 ， 网 络 体系 结 
构 只 是 一 个 逻辑 上 划分 的 结构 ， 真 正 起 作用 的 还 是 各 个 网 络 实体 ， 也 
忠 古 网 络 设备 软 / 硬 件 系 统 和 用 户 进 程 等 ;， 但 这 样 分 层 的 体系 结构 到 
说 有 什么 好 处 呢 ? 红 合 起 来 表现 在 以 下 几 个 主要 方面 : 


(1) 便于 方案 设计 和 维护 


这 是 分 层 网 络 体系 结构 的 最 重要 的 优点 。 对 于 一 个 复 灯 的 网 络 通 
言 过 程 ， 如 远程 的 计算 机 访问 或 网 络 访问 ， 在 通信 过 程 中 可 能 要 经 过 
许多 中 间 结 点 ， 也 可 能 要 进行 多 种 信息 格式 的 转换 ， 需 要 多 种 协议 共 
同 完成 。 如 果 没 有 一 个 分 层 结构 ， 进 行 网 络 系 统 设计 时 就 没 了 思路 ， 
到 发 该 设计 哪些 功能 ， 每 个 功能 的 实现 义 需 要 依赖 哪些 协议 和 服务 ， 
如 何 实现 这 些 服务 功能 等 都 不 是 很 明确 。 


有 了 分 层 结构 后 ， 在 我 们 进行 网 络 系统 设计 时 ， 程 序 开发 者 就 可 
以 根据 体系 结构 来 理解 计算 机 网 络 通信 的 流程 ， 并 看 看 在 每 一 层 中 需 
要 实现 哪些 类 型 的 功能 。 这 时 ， 人 负责 各 层 功 能 的 程序 开发 者 可 以 选择 
目 己 最 擅长 的 语言 或 技术 来 进行 开发 ， 而 不 用 管 其 他 层 的 功能 是 如 何 
开发 、 实 现 的 。 然 后 再 通过 一 些 服务 接口 束 可 以 实现 一 个 完整 的 网 络 
通信 任务 了 。 这 样 一 来 ， 束 可 以 把 一 个 大 的 网 络 通信 任务 分 解 成 几 个 


模块 ， 然 后 采取 个 个 击破 的 方法 ， 很 容易 整 可 以 实现 这 个 复杂 的 网 络 
通信 任务 了 。 


在 维护 方面 也 一 样 ， 如 有 果 没 有 分 层 结构 ， 一 旦 出 现 网 络 故障 ， 驳 
可 能 要 对 整个 网 络 的 各 方面 进行 故障 分 析 和 排除 ， 驶 像 大 海 搞 针 一 
样 ， 坚 无 目的 可 言 ， 显 然 工作 量 很 大 ， 而 有 了 分 层 结构 后 ， 我 们 束 可 
以 根据 不 同 层次 的 功能 和 实现 原理 ， 以 及 故障 特点 来 专门 针对 某 一 个 
或 少数 几 个 层次 进行 对 应 的 故障 分 析 和 排除 ， 这 样 显然 容易 多 了 。 


(2) 各 层 相 互 独 立 ， 技 术 升 级 和 扩展 灵活 性 好 


在 网 络 体系 的 分 层 结构 中 各 层 是 相互 独立 的 ， 也 融 是 没有 管理 和 
被 管理 的 区 分 ， 也 互 不 影响 ， 每 一 层 都 不 需要 知道 它 的 上 、 下 层 是 如 
何 工 作 和 进行 功能 实现 的 ， 仅 需要 上 层 知 道 该 如 调用 下 层 的 服务 ， 而 
下 层 义 该 如 何 为 上 层 提 供 服 务 即 可 。 这 一 方面 可 以 使 得 整个 复 洒 的 设 
计 任 务 变 得 比较 催 单 ， 另 一 方面 可 以 非常 灵活 地 实现 网 络 方案 扩展 或 
技术 升级 。 


我 们 知道 ， 网 络 技术 的 发 展 是 非常 快 的 ， 如 采 不 采用 分 层 结构 ， 
则 可 能 任何 一 方面 的 技术 更 新 ， 都 可 能 引起 全 局 的 配置 改动 ， 而 有 了 
分 层 网 络 体系 结构 后 ， 束 仅 需 对 相应 层次 和 对 应 的 服务 接口 进行 技术 
更 新 即 可 ， 其 他 层次 仍然 可 以 保持 不 变 ， 不 受 该 层 的 影响 。 同 样 ， 还 


可 仅 儿 对 某 一 个 或 几 个 层次 的 服务 进行 修改 ， 甚 至 在 不 需要 时 取消 该 
层 的 服务 。 


(3) 促进 标准 化 


通过 网 络 体系 结构 的 标准 化 ， 可 以 统一 各 开发 商 的 设计 标准 ， 实 
现 协 同 开 发 ， 并 人 允许 不 同 厂家 的 产品 想 互 通信 ， 极 大 地 促进 了 计算 机 
网 络 的 发 展 。 


经 验 之 谈 ”在 进行 网 络 体系 结构 分 层 时 应 使 每 一 层 的 功能 非常 明 
确 ， 而 且 比 较 容易 实现 。 如 采 层 次 划分 得 太 少 ， 则 会 使 每 一 层 的 协议 
太 复 淋 ， 不 利于 实现 ， 相 反 ， 如 采 层 次 划分 得 太 多 ， 每 一 层 的 功能 
太 单一 ， 层 与 层 之 间 的 接口 太 多 ， 同 样 会 影响 网 络 通 信和 效率 。 这 与 我 
们 在 设计 产品 生产 工艺 时 的 考虑 十 一 样 的 。 通 肖 每 一 层 都 要 完成 以 下 
几 方 面 的 任务 〈 可 以 是 其 中 一 种 或 儿 种 ) : 


口才 错 控 制 : 使 得 双方 的 网 络 通 信 更 加 稳定 、 可 靠 ， 不 出 现 网 络 
连接 中 断 和 数据 丢失 现象 。 

口 流量 控制 : 使 得 通信 双方 的 数据 发 送 和 接收 速率 相当 ， 以 避免 
数据 丢失 。 

口 分 段 和 重 闭 : 在 发 送 端 把 大 的 数据 块 划分 成 更 容易 发 送 和 接收 
的 小 数据 块 ， 然 后 在 接收 端 按照 对 应 数据 块 的 发 送 顺 序 重 新 组 逆 ， 恢 


复 为 原来 的 大 数据 块 。 


口 连接 建立 和 释放 :在 进行 正式 的 数据 交换 前 必须 先 建立 相应 的 
链 路 连接 ， 然 后 在 数据 交换 完 后 立即 释放 所 占用 的 链 路 ， 以 提高 链 路 
的 使 用 率 。 


3.4 网 络 体系 结构 中 的 通信 协议 


说 到 计算 机 网 络 体系 结构 ， 束 不 得 不 说 计算 机 网 络 中 的 通信 协议 
(也 就 是 在 标准 中 党 说 的 “通信 规程 了， 因为 这 些 通信 协议 就 是 计 
算 机 网 络 体系 结构 中 不 同 层次 中 的 具体 功能 实现 ， 也 束 是 我 们 通 浊 所 
说 的 各 层 所 提供 的 “服务 ”。 


3.4.1 ”理解 计算 机 网 络 通信 协议 


通信 协议 对 于 计算 机 网 络 的 重要 性 是 不 言 而 喻 的 ， 可 以 说 没有 通 
信 协 议 ， 束 没有 计算 机 网 络 ， 因 为 它 是 计算 机 网 络 中 的 “软件 ”组 成 部 
分 。 当 然 ， 事实 上 任何 一 种 计算 机 网 络 设备 都 不 可 能 仅 有 硬件 ( 俗 
称 “ 裸 机 >) ， 必 须 安 装 对 应 的 软件 系统 ， 而 这 些 软件 系统 中 就 包含 了 
所 文 持 的 通信 协议 。 每 一 种 计算 机 网 络 都 有 一 套 协 议 在 那里 文 持 着 。 
由 于 现在 计算 机 网 络 种 类 很 多 ， 所 以 现 有 的 网 络 通信 协议 的 种 类 也 很 
多 ， 如 常见 的 IEEE 802.3、PPP、PPTP、DNS、DHCP、HTTP 等 。 那 
么 什么 是 计算 机 网 络 通信 协议 呢 ? 其 实 很 简单 ， 只 要 联系 到 我 们 平帝 
与 别人 签 的 协议 是 什么 就 可 以 理解 计算 机 网 络 中 的 通信 协议 了 。 


在 我 们 平常 工作 和 生活 中 与 别人 签订 协议 的 目的 吏 是 约束 双方 或 
者 多 方 的 行为 ， 达 成 对 某 一 方面 或 者 多 个 方面 的 共识 。 计 算 机 网 络 通 


信 协 议 也 是 这 样 的 ， 它 束 古 约束 通信 双方 在 利用 某 协 议 进 行 通信 时 必 
须 遵 从 对 应 的 规则 和 约定 ， 以 达成 通信 共识 ， 否 则 彼此 各 不 相 认 ， 还 
如 何 通信 ? 这 区 像 一 个 只 会 中 文 ， 一 个 只 会 英文 的 两 个 人 对 话 ， 肯 是 
不 能 对 话 成 功 ， 因 为 他 们 相互 都 不 明日 对 方 在 说 什么 。 再 比如 ， 如 有 果 
有 几 个 人 共同 开发 一 个 方案 ， 结 有 果 他 们 各 目 使 用 的 程序 开发 语言 完全 
不 同 ， 且 不 能 相互 兼容 ， 这 样 最 终 肯 定 是 不 能 形成 完整 方案 的 。 所 
以 ， 计 算 机 网 络 通信 协议 可 以 理解 为 ， 为 了 使 网 络 中 的 不 同 设 备 能 进 
行 协 同 的 数据 通信 而 预先 制定 的 一 整套 通信 双方 相互 了 解 和 共同 遵守 
的 格式 和 约定 。 


计算 机 网 络 的 发 展 经 历 了 漫长 的 探索 过 程 ， 因 此 实际 并 不 是 先 制 
定好 了 统一 的 标准 再 研究 网 络 的 。 在 网 络 发 展 中 有 很 多 国际 组 织 和 路 
国 公 司 都 在 致力 于 网 络 通信 协议 的 制定 ， 并 产生 了 多 种 计算 机 网 络 体 
系 结构 模型 和 网 络 通信 协议 ， 而 且 有 更 多 的 组 织 和 公司 参与 了 开发 和 
完善 网 络 协议 的 工作 。 但 要 注意 的 是 ， 通 信 协 议 并 不 一 定 征 标准 ， 也 
可 能 仅 是 茶 个 公司 为 它们 的 网 络 设备 专门 开发 的 通信 协议 ， 不 能 用 于 
其 他 类 型 的 计算 机 网 络 中 ， 也 不 能 与 其 他 厂家 的 设备 互 连 。 


如 果 你 对 网 络 设备 有 所 了 解 的 话 ， 就 一 定 清楚 ，Cisco (思科 ) 有 
许多 自己 的 协议 ， 如 CDP (思科 发 现 协 议 ) 、DTP (动态 中 继 协 
议 ) 、VTP (VLAN 中 继 协 议 ) 、IGRP (内 部 网 关 协 议 ) 和 HSRP ( 主 
机 备份 路 由 器 协议 等， 这 些 协议 是 不 能 在 其 他 厂家 的 设备 上 使 用 的 


(除非 得 到 思科 的 授权 ) ， 也 不 能 与 其 他 三 家 设备 互 连 。 只 有 通过 国 
际 上 的 一 些 标准 化 组 织 (如 ISO、IEEE、IEC 之 类 的 ) 认可 后 才能 以 标 
准 形式 发 布 ， 如 ISO/RM 本 喘 也 是 一 个 协议 ， 但 因为 是 由 ISO 制 定 并 发 
布 的 ， 所 以 成 为 了 国际 标准 ， 还 有 IEEE 的 一 系列 以 太 网 、 城 域 网 、 
WLAN 等 协议 也 是 公认 的 国际 标准 。 


3.4.2 ”网 络 通信 协议 的 三 要 系 


网 络 体系 结构 中 的 各 项 功能 服务 ， 痢 是 通过 具体 的 通信 协议 来 实 
现 的。 要 实现 有 条 不 闲 地 进行 数据 通信 ， 通 信 双 方 束 必须 事先 约定 好 
相应 的 规则 ， 驳 像 我 们 平常 与 人 合作 做 一 件 事 时 事先 谈 好 合作 的 方式 
和 注意 事项 一 样 。 当 然 ， 计 算 机 网 络 中 的 数据 通信 规则 不 是 通信 双方 
具体 签订 的 ， 而 是 由 双方 所 采用 的 网 络 通信 协议 来 完成 的 。 


在 利用 网 络 通信 协议 进行 计算 机 网 络 通信 时 主要 涉及 以 下 三 个 方 
面 的 问题 : 一 是 要 实现 什么 样 的 网 络 服务 ， 二 是 如 何 实现 这 些 网 络 服 
务 ， 三 是 如 何 与 对 方 实现 协同 工作 。 这 三 个 方面 也 丈 对 应 了 计算 机 网 
络 通 信 协 议 的 三 个 基本 要 素 : 语义 、 语 法 和 同步 。 下 面 分 别 解释 它们 
各 目的 功能 。 


1 计 Y 


“语义 ”可 以 理解 为 “语意 ”是 用 来 解决 “做 什么 ”的 问题 ， 也 就 是 
描述 该 通信 协议 具体 用 来 完成 什么 功能 。 如 我 们 平常 工作 和 生活 中 所 
签 的 协议 中 的 标题 ， 或 者 主题 一 样 ， 让 人 家 一 看 就 知道 该 协议 是 用 来 
做 什么 的 。 双 方 在 对 等 层次 进行 通信 时 ， 首 先 就 要 确定 双方 所 使 用 的 
协议 的 “语义 "是否 一 样 ， 也 就 是 完成 的 功能 是 否 一 样 。 如 一 方 用 户 使 
用 的 是 L2TP 协 议 进行 VPN 通 信 (也 就 相当 于 他 说 “我 要 进行 L2TP VPN 


连接 ”) ， 而 另 一 方 使 用 的 却 是 PPTP 协 议 来 进行 VPN (也 就 相当 于 他 
说 “我 要 进行 PPTP VPN 连 接 ”) ， 目 的 都 不 一 样 ， 自 然 是 不 能 协商 成 功 
的 。 道 不 同 ， 不 相 为 谋 嘛 。 


在 通信 协议 的 “语义 ?部 分 还 包括 通信 协议 的 版 本 ， 束 像 我 们 平常 
所 签 的 协议 的 版 本 (主要 是 根据 签 协 议 的 时 间 先 后 来 判断 ) 一 样 。 不 
同 的 版 本 ， 所 能 实现 的 功能 ， 以 及 实现 的 方式 部 可 能 存在 大 的 差别 ， 
当然 通常 相 邻 版 本 的 通信 协议 是 癌 下 兼容 的 。 


93. 证 法 


“语法 ” 钙 用 来 规定 通信 时 的 信息 格式 ， 包 括 数据 及 控制 信息 的 格 
式 、 编 码 及 信号 电 平 等 ， 是 用 来 解决 “如 何 做 ”的 问题 的 。 如 我 们 平时 
所 签 的 协议 中 规定 的 具体 条 球 ， 规 定 如 何 确 你 达 到 最 终 目标 一 样 。 如 
果 双 方 进行 网 络 通信 时 所 用 的 通信 协议 一 样 ， 或 者 只 要 双方 所 使 用 的 
通信 协议 的 “语义 ?部 分 是 一 样 的 ， 束 相当 于 双方 的 目标 是 一 致 的 。 接 
下 来 的 问题 束 是 要 如 何 来 实现 双方 共同 的 目标 ， 完 成 相应 的 网 络 服 


务 。 


通信 协议 也 是 软件 ， 也 是 由 一 些 计算 机 程序 语言 来 开发 的 ， 所 以 
协议 的 具体 语法 依据 所 采用 的 程序 开发 语言 的 语法 规则 来 进行 。 尽 管 
有 时 ， 双 方 所 使 用 的 通信 协议 名 称 并 不 一 样 ， 但 只 要 其 语义 部 分 相 
同 ， 且 双方 都 能 识别 对 方 的 语法 规则 ， 仍 然 可 以 进行 通信 。 束 相当 于 


我 们 与 别人 对 话 时 ， 如 有 果 双 方 都 全 几 种 语言 ， 尽 管 母语 不 一 样 ， 但 是 
都 能 够 听 慌 对 方 在 说 什么 ， 明 白 对 方 要 做 什么 仍然 可 以 进行 交流 、 
共同 完成 某 项 任务 。 


3. 同 步 


“同步 ” 钙 用 来 解决 “做 的 次 序 ” 问 题 的 ， 也 就 古 通 信 双 方 要 完成 某 
项 网 络 服务 ， 必 须 依 据 什 么 样 的 流程 ， 匹 配 什么 样 的 速率 、 什 么 样 的 
电 笠 来 进行 。 在 网 络 通 信 中 同步 又 称 为 "握手 ”。 通 信 协 议 是 用 来 实现 
某 项 网 络 服务 的 ， 但 在 通信 双方 必须 保持 一 定 的 程序 执行 步骤 ， 驳 像 
打 电 话 时 的 一 问 一 答 模 式 一 样 。 否 则 ， 者 一 方 的 请 求 得 不 到 对 方 的 应 
答 ， 束 会 出 现 程 序 错 误 ， 最 终 导 人 致 通信 失败。 


同时 ， 因 为 程序 执行 的 各 个 步骤 之 间 是 有 相互 依赖 性 的 ， 有 时 要 
依据 上 一 步骤 的 用 户 选择 来 做 出 下 一 步 的 选择 。 再 有 ， 还 要 考虑 通信 
双方 “说 话 ” 的 速度 问题 。 如 因 某 些 原 因 ， 一 方 的 程序 执行 效率 比较 高 
(如 网 络 带宽 高 ， 设 备 性 能 好 ) ， 另 一 方 的 程序 执行 效率 比较 低 〈 如 
网 络 市 宽 低 ， 设 备 性 能 过) ， 这 时 束 得 双方 协商 好 ， 如 何 保持 一 个 双 
方 都 可 接受 的 执行 速率 ， 这 样 才能 做 到 步调 一 致 ， 以 防 出 现 老 错 。 其 
实 这 束 古 我 们 在 后 面 将 要 经 常 提 到 的 “流量 控制 *、“ 拥 塞 控制 * 功 能。 
如 采 不 协商 好 传输 速率 的 话 ， 一 方 传输 完 数据 好 入 了 ， 对 方 还 在 接 
收 ， 这 时 可 能 会 因为 传输 延 时 等 问题 而 出 现 数据 丢失 ， 从 而 导致 对 方 
接收 到 的 数据 不 完整 。 就 像 我 们 平时 打 电话 一 样 ， 如 果 双 方 都 讲 个 不 


停 ， 那 谁 也 听 不 清 对 方 说 什么 ， 或 者 一 方 说 话 太 快 ， 对 方 根本 听 不 


N==3 
} 表 。 


第 4 章 ”物理 层 


从 本 章 开始 ， 融 要 正式 进入 本 书 的 主题 了 ， 这 意味 着 将 正式 进入 
本 书 最 难 的 部 分 。 本 书 以 图 3-5 所 示 的 那个 建议 的 五 层 体 系 结构 为 例 ， 
对 网 络 体系 结构 各 层 进 行 全面 、 深 入 的 分 析 。 虽 然 这 些 技 术 看 起 来 很 
深奥 ， 但 它们 的 确 是 计算 机 网 络 的 基础 知识 ， 对 于 我 们 理解 计算 机 网 
络 通 信和 原理 ， 分 析 和 排除 计算 机 网 络 故障 ， 以 及 设计 网 络 系统 等 都 是 
必要 的 。 


通过 对 第 3 章 的 学 习 ， 我 们 已 经 知道 ， 在 所 有 计算 机 网 络 体系 结构 
中 的 最 低层 都 是 “物理 层 ”( 尽 管 在 TCP/IP 协 议 体系 结构 中 没有 单独 划 
分 ) 。 如 果 把 整个 计算 机 网 络 通 信和 看 成 一 个 立体 的 层次 模型 的 话 ， 那 
么 这 个 通信 模型 的 展 层 束 是 “物理 层 "， 因 为 计算 机 网 络 设备 之 间 的 连 
接 必须 依靠 物理 层 的 传输 介质 和 相关 协议 进行 。 束 像 我 们 建造 万 丈 高 
楼 都 离 不 开 最 发 层 的 地 基 一 样 ， 不 可 能 建造 一 个 空中 楼 阁 。 同 样 ， 物 
理 层 也 是 所 有 计算 机 网 络 通信 的 必 经 之 路 ， 尽 管 这 “路 "有 许多 种 ， 束 
像 我 们 旅行 时 必须 要 有 “路 ”〈 可 以 是 泥巴 路 、 柏 油 马 路 、 水 泥 路 、 铁 
路 等 ) 可 走 一 样 ， 否 则 不 要 说 到 国外 ， 就 是 出 门 都 可 能 寸步 难 行 。 


本 章 围绕 物理 层 的 机 械 特性 、 电 气 特 性 、 功 能 特性 和 通信 规程 这 
几 个 方面 进行 展开 性 的 介绍 ， 主 要 包括 数据 通信 的 基本 模型 、 数 据 传 
输 速率 、 数 据 传输 类 型 、 数 据 传输 方式 、 数 据 传输 模式 、 数 据 通信 方 


式 、 信 号 类 型 、 信 和 号 编码 、 信 和 号 调制 与 解 调 、 数 据 抽 样 、 信 道 复 用 、 
传输 介质 和 主要 物理 接口 规程 等 。 其 中 涉及 许多 非常 复杂 的 技术 原 
理 ， 如 信号 编码 、 信 号 调制 与 解 调 、 妹 奎 斯 特 准则 、 香 农 公 式 、 数 据 
抽样 定律 等 ， 这 些 大 家 要 着 重 理 解 。 


4.1 物理 层 概 述 


计算 机 网 络 的 “物理 层 ” 位 于 各 计算 机 网 络 体系 结构 的 底层 

(TCP/IP 体 系 结构 中 的 “物理 层 ” 功 能 是 集中 划分 在 最 低 的 “网 络 访问 
层 ” 中 ) ， 负 责 在 物理 传输 介质 之 上 为 “数据 链 路 层 ” 提 供 一 个 原始 比特 
流 〈 也 就 是 数据 是 以 一 个 个 0 或 1 的 二 进 制 代码 形式 表示 的 ) 的 物理 连 
接 。 但 要 特别 注意 的 是 , “物理 层 " 并 不 是 特 指 茶 种 传输 介质 ， 而 是 指 
通过 传输 介质 ， 以 及 相关 的 通信 协议 、 标 准 建 立 起 来 的 物理 线路 。 也 
束 是 说 “物理 层 ” 起 到 “ 修 路 ”的 作用 ， 只 不 过 这 条 路 是 用 于 计算 机 网 络 
通信 的 “线路 ”过 了 。 


4.1.1 物理 层 的 主要 作用 


讲 到 网 络 体系 结构 中 的 “物理 层 "， 首 先 要 知道 的 束 是 它 到 搬 有 什 
么 作用 。 相 对 其 他 各 层 来 说 , “物理 层 ” 尽 管 因 传输 介质 类 型 、 物 理 接 
口 以 及 它们 的 通信 规程 (也 就 是 “通信 协议 ”) 类 型 都 非常 多 ， 所 以 包 


括 的 技术 和 规程 都 比较 多 ， 但 其 主要 功能 相对 来 说 还 是 比较 单一 的 ， 
具体 包括 : 


(1) 构建 数据 通路 


“数据 通路 ? 吏 是 完整 的 数据 传输 通道 ， 可 以 是 一 段 物理 介质 ， 也 
可 以 是 由 多 段 物 理 介质 连接 而 成 的 。 一 次 完整 的 数据 传输 ， 包 括 激活 
物理 连接 、 传 送 数据 、 终 止 物理 连接 三 个 主要 阶段 。 所 请“ 激活 物理 连 
接 ”， 吏 是 不 管 有 多 少 段 物 理 介质 参与 ， 在 通信 的 两 个 数据 终端 设备 间 
都 要 在 电气 上 连接 起 来 ， 形 成 一 条 可 以 在 上 面 连续 传输 数据 的 通路 。 


(2) 透明 传输 


物理 层 中 可 用 的 传输 介质 类 型 《如 不 同类 型 的 同 轴 电 缆 、 双 绞 线 
和 光纤 等 ， 非常 多 ， 各 自 义 有 相应 的 通信 协议 和 标准 来 支持 ， 这 就 决 
定 了 不 同 的 计算 机 网 络 可 能 有 不 同 的 “路 ”。 物 理 层 除了 要 把 这 些 不 同 
的 “路 ”修好 外 ， 还 要 确保 这 些 不 同 的 “路 ”能 “连通 ?起 来 ， 形 成 通路 ， 
最 终 实 现 把 比特 流传 输 到 对 端 “ 物 理 层 ”， 然 后 癌 “ 数 据 链 路 层 ” 提 交 的 
国 计 ]* 


要 实现 上 述 功 能 ， 需 要 物理 层 具 有 屏蔽 不 同 传输 介质 类 型 和 通信 
协议 的 功能 ， 让 进行 网 络 通信 的 各 方 只 看 到 有 “路 ”可 行 ， 而 不 管 修 这 
些 “ 路 ”所 用 的 具体 “材料 ”和 相关 标准 ， 这 就 是 物理 层 的 “透明 传输 ” 功 


E。 有 关 这 些 传输 介质 类 型 和 通信 协议 、 标 准将 在 本 章 后 面具 体 介 
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(3) 传输 数据 


无 论 是 从 网 络 体系 结构 中 哪 层 发 起 的 通信 ， 最 终 的 数据 都 得 通过 
最 低 的 “物理 层 ” 传 输出 去 ， 因 为 这 是 网 络 通信 的 唯一 物理 通道 。 但 “ 物 
理 层 ”的 传输 单位 是 比特 〈bit， 也 就 是 “位 ”>， 数 据 中 的 一 个 二 进 制 的 0 
或 1 就 代表 1 位 ) 。"“ 物 理 层 "的 基本 作用 是 在 发 送 端 通过 物理 层 接口 和 
传输 介质 将 数据 按 比特 流 的 顺序 传送 到 接收 端的 物理 层 。 


(4) 数据 编码 


要 使 数据 能 在 “物理 层 " 上 有 效 、 可 靠 地 传输 ， 节 关键 的 是 要 确保 
数据 比特 流 能 在 对 应 的 “信道 ”中 正常 通过 。 这 束 涉 及 “物理 层 ” 的 数据 
编码 功能 ， 因 为 不 同 传输 介质 所 支持 的 数据 编码 类 型 不 一 样 《如 归 和 零 
码 、 非 归 零 码 、 曼 彻 斯 特 码 、 差 分 曼彻斯特 码 等 ; 。 这 些 编码 类 型 也 
将 在 本 章 后 面具 体 介 绍 。 


(5) 数据 传输 管理 


“物理 层 ” 还 具有 一 定 的 数据 传输 管理 功能 ， 如 基于 比特 流 的 数据 
传输 流量 控制 、 差 错 控 制 、 物 理 线路 的 激活 和 释放 等 。 


4.1.2 ”物理 层 所 定义 的 特性 


总 体 来 说 ,，“ 物 理 层 ”的 主要 任务 是 定义 与 传输 介质 、 连 接 郁 及 其 
接口 相关 的 机 械 特性 、 电 气 特性 、 功 能 特性 和 规程 〈 也 就 是 我 们 通常 
所 说 的 “协议 ”) 特性 这 四 个 方面 。 这 些 特性 的 规定 都 相当 重要 ， 因 为 
有 了 统一 的 标准 后 ， 各 设备 生产 厂家 才能 以 相同 的 标准 来 设计 、 生 
产 、 制 作 这 些 传输 介质 、 连 接 絮 、 接 口 ， 并 使 用 对 应 的 通信 协议 实现 
彼此 互 连 。 


1. 机 械 特性 


物理 层 的 “机 械 特性 ”定义 了 传输 介质 接线 紫 、 物 理 接口 的 形状 和 
尺寸 、 引 线 数目 和 排列 顺序 ， 以 及 连接 器 与 接口 之 间 的 固定 和 锁定 装 
= 


在 计算 机 网 络 中 ， 我 们 常见 的 传输 介质 十 同 轴 电 统 、 双 绞 线 、 光 
纤 等 ， 其 实 还 有 一 种 ， 那 就 是 在 路 由 器 S 口 (串口 ) 连接 时 ， 以 及 以 前 
各 种 Modem 与 计算 机 连接 时 所 使 用 的 第 行 电 统 。 不 管 是 哪 种 传输 介 
质 ， 在 用 于 连 网 时 都 需要 安装 了 连接 需 的 网 线 电缆 和 设备 或 网 卡 中 的 
对 应 接口 。 


细 同 轴 电 缆 的 连接 器 〈 称 之 为 BNC 头 ) 有 两 种 : 一 种 是 单一 连接 
苍 ， 直 接 与 BNC 网 卡 或 者 与 BNC 头 连接 ;一 种 是 一 种 T 形 连接 套 ， 三 端 


分 别 用 于 连接 细 同 轴 电 统 网 线 两 端的 连 授 此 和 BNC 网 卡 ， 分 别 如 图 4- 


1a、b 所 示 ， 制 作成 的 细 同 轴 电 比如 图 4-1c 所 示 ，BNC 网 卡 如 图 4-1d 所 
不 o 


用 于 安装 在 细 同 轴 电 绕 1 
< SS 于 与 左 图 细 同 轴 


电缆 连接 器 连接 


与 细 同 轴 电 绕 
连接 器 连接 


安装 了 连接 器 
的 细 同 轴 电 绕 


pn wa 


> d) 


图 4-1 细 同 轴 电 统 BNC 连 接 器 、 细 同 轴 电 统 网 线 和 BNC 网 卡 


对 于 双 绞 线 以 太 网 来 说 ， 连 接 右 就是 我 们 通常 所 说 的 “水 晶 
头 ”( 又 称 RJ-45 接 头 ) ， 如 图 4-2a 所 示 ; 安装 了 水 晶 头 连接 器 的 双 绞 网 
线 如 图 4-2b 所 示 ， 而 网 络 接口 (通常 称 为 RJ-45 以 太 网 口 ) 就 是 以 太 网 
卡 或 者 交换 机 、 路 由 姨 等 设备 的 以 太 网 端口 ， 如 图 4-2c 所 示 。 


RJ-45 以 太 网 口 


b) 双 绥 网 线 c) 以 太 网 网 卡 
图 4-2” 双 绞 网 线 连 接 器 、 双 绞 网 线 和 双 绞 线 以 太 网 网 卡 


说 明 ”因为 光纤 种 类 繁多 ， 导 致 其 连接 器 和 接口 种 类 也 很 多 ， 在 
此 就 不 举例 说 明了 ， 本 章 后 面 介绍 光纤 时 再 做 说 明 。 


连接 路 由 器 的 S 口 ， 和 以 前 Modem 连 接 PC 时 所 用 的 串口 统称 为 RS- 
232 接 口 。 它 有 多 种 类 型 的 连接 器 (接口 ) ; 25 必 连接 器 对 应 的 标准 为 
ISO-2110、EIARS-232C 和 EIARS-366A 等 ， 可 用 于 串 / 并 行 音频 调制 解 
调 器 、 公 用 数据 网 络 接 口 、 电 报 (包括 用 户 电报 ) 接口 和 自动 呼叫 设 


备 中 ，34 蕊 连接 器 对 应 的 标准 为 ISO-2593， 可 用 于 CCITT V.25 建 议 的 


毁 市 调制 解 调 絮 中 ;，37 心 和 9 心 连接 器 对 应 的 标准 为 ISO-4902， 可 用 于 
串 行 音频 和 宽带 调制 解 调 器 中 ， 与 EIARS-449 标 准 兼 容 ，15 忌 连接 器 对 
应 的 标准 为 I SO-4903， 可 用 于 CCITT X.20、X.21 和 X.22 建 议 中 规定 的 
公用 数据 网 接口 中 。 


无 论 哪 种 类 型 的 RS-232 接 口 ， 都 同时 有 用 来 连接 DTE (Data 
Terminal Equipment， 数 据 终端 设备 ) 设备 的 孔 端 连接 器 (也 就 是 通常 
所 说 的 “ 母 头 ”) 和 用 来 连接 DCE (Data Communications Equipment， 数 
据 通信 设备 ) 设备 的 针 端 连接 器 (也 就 是 通常 所 说 的 “ 公 头 ”) 。 图 4-3 
所 示 的 就 是 DB-25 和 DB-9 两 种 连接 器 。 制 作 好 的 电缆 上 都 会 一 端 是 


DIE 连接 万 ， 邦 一 站 是 DCE 连 接 各 。 


图 4-3 DB-25 和 DB-9 连 接 器 


DTE 钙 具有 一 定 的 数据 处 理 能 力 和 数据 收发 能 力 的 设备 ， 如 PC 
机 ;，DCE 是 在 DTE 和 传输 线路 之 间 提 供 信号 要 换 和 编码 功能 ， 并 人 负责 
建立 、 保 持 和 释放 链 路 连接 的 设备 ， 如 各 种 Modem。 路 由 器 一 般 同时 


担当 DTE 和 DCE 双 重 角色 ， 当 然 具 体 角色 是 由 路 由 器 上 不 同 的 接口 担 
当 的 。DCE 设 备 需要 与 DTE 设 备 对 接 。 


物理 层 的 “电气 特性 ”规定 了 在 物理 连接 上 传输 二 进 制 比特 流 时 线 
路 上 信号 电压 的 高 低 、 阻 抗 严 配 情况 ， 以 及 传输 速率 和 传输 距离 限制 
等 参数 属性 。 盾 期 的 物理 层 电气 特性 标准 定义 的 是 物理 连接 边界 点 上 
的 电气 特性 ， 而 目前 使 用 的 新 电气 特性 标准 定义 的 都 是 接口 发 送 器 和 
接收 亏 的 电 硕 特性 ， 同 时 还 给 出 了 互 连 电 绑 的 相关 规程 。 目 前 所 使 用 
的 新 的 物理 层 接口 电气 特性 主要 分 为 三 类 : 非 平 衡 型 、 差 分 接收 需 的 
非 平衡 型 和 平衡 型 。 


这 里 所 说 的 “ 阅 衡 "与 “ 非 平 衡 * 其 实 古 根据 发 送 右 发 送信 和 号， 或 首 接 
收 器 接收 信号 时 信号 电 平 是 由 单 根 线 的 电 平 值 决 是 ， 还 是 由 两 根 线 之 
间 的 电 平 差 值 决定 而 判断 的 。“ 和 平衡" 传输 模式 中 都 是 采用 一 对 线 〈 除 
了 地 线 之 外 ) 进行 老 分 信号 传输 的 ， 信 和 号 电 乎 是 由 两 根 线 上 的 电 平 老 
决定 的 ， 而 “ 非 平衡 "传输 模式 则 只 用 一 根 导线 ( 除 地 线 外 ) 进行 非 差 
分 信号 的 传输 ， 信 号 电 平 仅 由 一 根 信号 线 上 的 电 平 决定 。 


说 明 “ 关 分 信号 ?” 征 指 两 个 物理 信号 间 存 在 电 平 之 兰 ， 又 称 “ 震 模 信 
号 ”， 用 一 个 差 值 表示 。 也 束 古 指 最 终 的 信号 电 平 不 是 由 某 一 条 导线 上 
的 信号 电 平 来 决定 的 ， 而 是 由 两 根 导线 的 电 平 差 值 决 定 的 。 使 用 差分 


言 号 的 传输 残 叫 做 “过 分 传输 ”， 区 别 于 传统 的 一 根 信号 线 、 一 根 邯 线 
的 做 法 ， 差 分 传输 是 在 两 根 线 上 同时 传输 信号 ， 而 且 这 两 个 信号 的 振 
幅 相 等 、 相 位 相反 。 在 这 两 根 线 上 的 传输 的 信号 就 是 “差分 信号 ”。 信 
接收 器 通 过 比较 这 两 个 电压 的 差 值 来 判断 发 送 器 发 送 的 是 逻辑 9， 还 
。 但 要 注意 ， 在 电路 板 上 ， 差 分 信号 的 两 条 导线 的 布线 必须 是 
` 等 宽 、 某 密 靠 近 且 在 同一 层面 的 两 根 线 。 只 有 这 样 才 可 能 做 到 
导线 上 的 差分 信号 同 幅 、 反 相 、 同 步 传 输 。 


J 
NR 
Ft 
了 
| 一 
| 


天 咎 秋 
林 


是 | 
ml 
Ss 
二 
Sr 
于 
Et 
KU 


从 严格 意义 上 来 讲 ， 所 有 电压 信号 都 是 差分 的 ， 因 为 一 个 电压 只 
能 是 相对 于 男 一 个 电压 而 言 的 。 在 某 些 系 统 里 ， 系 统 “地 ”被 用 作 电 压 
基准 点 。 此 时 ， 这 种 信号 规划 被 称 为 单 问 的， 因为 信号 古 用 单条 导线 
上 的 电压 来 表示 的 。 一 个 差分 信号 作用 在 两 条 导线 上 ， 信 号 值 古 两 条 
导线 间 的 电压 差 ， 而 且 这 两 个 电压 的 平均 值 还 是 会 保持 一 致 的 ， 因 为 
干扰 会 同时 作用 于 两 条 导线 上 ， 并 且 效 果 一 样 。 


我 们 用 一 个 比喻 来 说 明 。“ 莽 分 信号 ? 束 好 比 是 跷 跷 板 上 的 两 个 
人 ， 当 一 个 人 被 踪 上 去 的 时 候 ， 另 一 个 人 被 蹊 下 来 了 ， 但 是 他 们 的 乎 
均 位 置 (也 就 是 那个 支点 ) 是 不 变 的 。 这 就 是 “差分 信号 ”传输 的 原理 
和 主要 优势 。 因 为 这 种 反 相 、 等 幅 差分 信号 传输 方式 可 以 有 效 地 抑制 
外 界 干 扰 ， 具 体 原 理 将 在 后 面 的 “平衡 型 ?接口 标准 中 介绍 。 


(1) 非 平衡 型 


“ 非 平 衡 型 "接口 一 般 是 指 早期 采用 分 立 元 件 技术 设计 的 接口 ， 其 

言 写 发 送 胡 和 接收 锅 均 采用 非 平 衡 方式 工作 。 即 每 路 信号 仅 使 用 一 根 
导线 传输 (是 “单线 传输 方式 ”) ， 然 后 所 有 信号 共用 一 根 信号 地 线 

(发 送 器 和 接收 器 的 地 线 是 相连 的 ， 形 成 统一 的 接地 ) ， 如 图 4-4a 所 


修 ° 


发 送 佣 差分 接收 需 


b ) 差分 接收 费 的 非 平 衔 型 (EIA RS-423A ) 


平衡 发 送 器 差分 接收 器 


c ) 平衡 型 ( EIA RS-422A ) 


图 4-4 三 种 物理 层 接口 电气 特性 


这 种 非 平 衡 接 口中 采用 的 是 非 差 分 传输 方式 ， 一 路 信号 只 在 一 根 
导线 上 传输 ， 也 就 没有 为 一 条 导线 上 的 等 幅 、 反 相 的 信和 号， 所 以 这 路 


言 号 传输 到 了 接收 器 后 ， 它 的 电压 也 只 由 这 条 导线 上 的 信和 号 电 平 决 
定 。 这 样 一 来 ， 如 果 外 界 有 一 个 信号 进行 干扰 ， 就 会 直接 谷 加 在 这 条 
导线 的 信号 上 ， 导 致 最 终 的 信号 失真 。 正 因 如 此 ， 在 这 种 平衡 型 接口 
标准 (典型 代表 为 CCITT V.28 建 议 的 EIA RS-232C) 中 所 采用 的 信号 电 
平 比较 高 ， 用 +5V~+15V 表 示 二 进 制 “0*"， 用 -5V~-15V 表 示 二 进 制 “1”。 
其 目的 就 是 为 了 使 干扰 信号 对 真正 的 信号 产生 较 小 影响 ， 毕 况 干 扰 信 
号 电 平 通常 不 会 很 高 。 如 果 信 号 电 平 比较 低 的 话 ， 干 扰 信 号 的 影响 就 
会 很 严重 了 。 


另外， 同样 由 于 使 用 的 是 单线 传输 ， 没 有 一 个 用 来 抵消 各 种 干扰 
和 串扰 的 线 对 ， 不 同 导线 上 的 信号 串扰 也 比较 严重 ， 所 以 在 这 种 接口 
中 ， 信 和 号 传输 速率 比较 低 (速率 越 高 ， 线 间 的 串扰 越 大 。 就 像 我 们 跑 
步 一 样 ， 跑 得 越 快 ， 所 产生 的 风 对 其 他 相 邻 跑道 上 的 运动 员 干 扰 越 
大 ) ， 规 定 在 20kbps 以 内 ， 连 接 两 个 接口 的 电缆 长 度 限 于 15m 以 内 (也 
是 为 了 尽量 降低 线 间 串扰 对 有 用 信和 号 的 影响 ) 。 


(2) 差分 接收 器 的 非 平衡 型 


差分 接收 器 的 非 平 衡 型 〈 又 称 “ 新 的 非 平 衡 型 ") 是 原来 “ 非 平衡 
型 的 改进 版 本 ， 接 口中 的 发 送 亏 采用 的 是 上 面 介 绍 的 非 平 衡 工 作 方式 
(也 就 是 一 路 信号 也 只 用 一 条 导线 进行 传输 ) ， 但 接收 器 采用 “ 差 
分 ?工作 方式 ， 且 发 送 右 和 接收 融 不 是 共用 一 条 地 线 。 在 这 种 接口 中 ， 
发 送 厚 仍 使 用 一 根 导线 发 送信 号 ， 但 在 接收 痊 端 是 两 条 寻 线 输入 的 ， 


除了 发 送 右 直接 驱动 的 那 条 信号 线 外 ， 还 有 束 古 接 目 发 送 器 地 线 的 那 
条 导线 (如 图 4-4b 所 示 ) ， 接 收 信号 的 最 终 电 乎 是 由 这 两 条 导线 上 的 差 
值 来 决定 的 。 


在 这 种 新 型 的 非 平 衡 型 接口 标准 (典型 代表 束 是 CCITT V.10/X.26 
建议 的 EIA RS-423A) 中 ， 发 送 器 采用 单线 驱动 ， 接 收 器 采用 双 端 输 
入 ， 接 收 器 最 终 信 号 的 电 平 就 是 这 两 条 线 的 差 值 (进行 减法 运算 ) ， 
所 以 称 为 “差分 接收 器 ?”。 如 果 没 有 干扰 和 串扰 ， 接 收 器 的 最 终 信和 号 就 
是 发 送 器 发 送 过 来 的 那个 信号 电 平 ; 如 果 有 干扰 或 串扰 ， 那 么 这 些 信 
号 会 以 相同 振幅 、 相 反 相 位 半 加 在 这 两 条 输入 导线 上 ， 最 终 接收 器 上 
的 差分 结果 就 可 以 抵消 这 部 分 干扰 或 串扰 信号 。 如 现在 发 送 器 端 发 送 
一 个 5V 的 信号 到 接收 器 端 ， 而 同时 在 传输 过 程 中 有 一 个 1V 的 干扰 信 
号 ， 那 么 在 发 送 有 用 信号 的 那 条 导线 上 的 电 平 就 是 5V+1V=6V， 而 接 到 
发 送 器 地 线 的 那 条 导线 中 ， 电 平 就 会 变 为 1V， 最 终 在 接收 器 端 经 过 减 
法 运算 (因为 要 求 它们 的 电 平 差 ) ， 所 得 信号 电 平 就 为 6V-1V=5V， 仍 
保持 不 变 。 


因为 在 接收 费 端 采用 了 差分 工作 方式 ， 可 抵消 外 界 干 扰 或 线 间 串 
扰 ， 所 以 它 的 信号 电 平 可 以 比较 低 (这 对 电路 中 的 芯 厂 都 是 非常 有 利 
的 ) ， 用 +4v~+6v 表 示 二 进 制 “0”， 用 -4V~-6V 表 示 二 进 制 <1”。 同 样 传 
输 速 率 也 可 以 比较 高 ， 在 10m 以 内 的 近 距 离 情 况 下 ， 传 输 速 率 可 达 
300kbps， 但 当 传 输 距离 达到 1000m 时 ， 信 号 传输 速率 只 有 3kbps 以 下 。 


(3) 平衡 型 


“平衡 型 "接口 是 目前 最 广泛 采用 的 一 种 物理 层 接口 ， 一 般 是 采用 
集成 电路 技术 设计 的 。 它 规定 “发 送别 ”采用 双 线 平衡 发 送 方式 ， 而 “ 接 
收 句 ” 则 采用 差分 处 理 方 式 ， 也 不 共用 地 线 ， 如 图 4-4c 所 示 。 


在 平衡 型 接口 标准 (典型 代表 为 CCITT V.11/X.27 建 议 的 EIA RS- 
422A) 中 规定 ， 两 条 导线 承载 同样 的 传输 ， 但 它们 是 等 幅 、 反 相 的 ， 
反 相信 号 看 上 去 就 像 源 信号 在 镜子 中 的 影像 。 接 收 端 并 不 侦 听 任何 一 
个 实际 的 信号 ， 而 是 检测 两 个 信号 的 差 值 。 当 两 个 反 相 信和 号 抵达 接收 
端 时 和 需 进 行 减法 运算 ， 因 为 互 为 反 相 ， 所 以 两 者 相 减 的 结果 就 是 第 
个 信号 值 的 两 倍 。 比 如 ， 在 某 个 特定 时 间 点 ， 第 一 个 信号 为 +5V， 那 么 
第 二 个 信号 就 是 -5V， 两 者 相 减 5V-(-5V)=10V， 相 当 于 放大 了 原始 信 
号 。 同 样 ， 由 于 接收 历 采 用 了 差分 运算 ， 所 以 就 像 前 面 介 绍 的 “ 非 平衡 
型 ?接口 中 所 诠释 的 差分 运算 原理 一 样 ， 它 也 可 以 抵消 外 界 信号 干扰 和 
线 间 信和 号 串扰 。 因 为 如 果 有 噪声 加 入 到 传输 过 程 中 ， 那 么 噪声 将 以 同 
样 的 方式 影响 两 个 信号 。 


比如 ， 在 某 个 特定 时 间 点 ， 第 一 条 导线 上 的 信号 为 +5V， 第 二 条 导 
线 上 的 信和 号 束 是 -5V， 假 设 噪声 电 平 为 LIV， 则 第 一 条 导线 上 的 信号 受 
干扰 后 为 +6V， 第 二 条 导线 上 的 信和 号 受 干扰 后 为 -4V。 如 末 品 声 
为 -1V， 则 第 一 条 导线 上 的 信号 受 干 扰 后 为 +4V， 第 二 条 导线 上 的 信和 号 
受 干 扰 后 为 -6V。 这 时 候 接 收 端 取 两 个 信号 的 差 值 。 但 在 这 里 要 特别 注 


意 的 是 ， 不 论 噪 声 是 正 还 是 负 ， 不 论 噪 声 有 多 大 ， 在 相 减 的 过 程 中 都 
被 抵消 了 ， 出 来 的 差 值 都 是 10V。 再 经 过 10V 到 5V 的 转换 运算 ， 接 收 端 
可 以 收 到 和 发 送 端 一 模 一 样 的 信号 。 这 种 抵消 的 能 力 使 得 平衡 型 传输 
获得 了 超级 的 传输 速率 ， 同 时 具有 较 高 的 抗 干 扰 能 力 。 所 以 ， 在 平衡 
型 接口 标准 中 也 可 以 用 较 低 的 信号 电 平 ， 规 定 用 +4V~+6V 表 示 二 进 
制 “0”， 用 -4V~-6V 表 示 二 进 制 “1”。 这 种 接口 的 信号 传输 速率 也 可 以 比 
较 高 ， 当 在 10m 以 内 的 近 距 离 传输 时 ， 速 率 可 达 10Mbps， 而 当 传输 距 
离 达 到 1000m 时 ， 信 和 号 传输 率 在 100kbps 以 下 。 


3. 功 能 特性 


物理 层 的 “功能 特性 ?是 指明 传输 介质 中 各 条 线 上 所 出 现 的 某 一 电 
平 的 含义 ， 以 及 物理 接口 各 条 信号 线 的 用 途 ， 包 括 : 接口 信号 线 的 功 
能 规定 ， 接 口 信号 线 的 功能 分 类 。 


CCITT V24 建 议 采 用 一 根 接 口 信号 线 定义 一 个 功能 的 方法 ， 这 一 
方法 是 规定 接口 信号 线 功能 的 主要 标准 之 一 。 而 CCITT X.24 则 建议 采 
用 每 根 接口 信号 线 定义 多 个 功能 的 方法 ， 这 种 多 重复 用 一 根 接 口 信和 号 
线 的 方法 可 以 减少 接口 信号 线 的 数量 。 接 口 信号 线 按 功能 一 般 可 分 为 
数据 信号 线 、 控 制 信号 线 、 定 时 信号 线 和 接地 线 等 四 类 。 信 号 线 的 名 
称 可 以 采用 数字 、 字 母 组 合 或 英文 缩写 三 种 方式 来 命名 。CCITT V24 
建议 采用 数字 命名 法 。 


按 CCITT V.24 建 议 的 接口 信号 线 命名 方法 ，DTE-DCE 接 口 信号 线 
的 名 称 的 第 一 位 均 为 "1”， 所 以 也 有 人 将 其 称 为 100 系 列 接口 信号 线 。 
相应 的 ，CCITT V.24 建 议 用 于 DTE-ACE (Automatic Calling 
Equipment， 自 动 呼叫 设备 ) 接口 信号 线 的 名 称 的 第 一 位 均 为 “0”， 故 又 
有 将 这 种 接口 标准 称 为 200 系 列 接口 信号 线 的 说 法 。 还 有 其 他 一 些 常用 
的 接口 标准 ， 如 X.25 (分 组 型 公用 数据 网 DTE-DCE 接 口 标准 ) 、X.20 
(公用 数据 网 起 止 式 传输 业务 的 DTE-DCE 接 口 标准 ) 、X.20 bis (连接 
在 公用 数据 网 上 的 V 系 列 建议 起 止 式 传输 DTE-DCE 兼 容 性 接口 标准 ) 


类 


4. 规 程 特性 


物理 层 的 “规程 特性 ”指明 利用 接口 传输 比特 流 的 全 过 程 及 各 项 用 
于 传输 的 事件 发 生 的 合法 顺序 ， 包 括 事件 的 执行 顺序 和 数据 传输 方 
式 ， 即 在 物理 连接 建立 、 维 持 和 交换 信息 时 ，DTE/DCE 双 方 在 各 自 电 
路 上 的 动作 序列 。 


4.2 ”数据 通信 基础 


物理 层 是 各 种 计算 机 网 络 体系 结构 的 最 确 层 ， 数 据 在 网 络 线路 上 
的 实际 传输 都 是 在 物理 层 线 路 上 进行 的 ， 所 以 数据 通信 的 本 质 其实 就 
是 物理 层 的 比特 流传 输 。 在 正式 介绍 物理 层 中 的 一 些 具体 技术 前 ， 本 
万 移 来 介绍 在 计算 机 网 络 中 进行 数据 通信 的 基础 知识 ， 包 后 数据 通信 
基本 模型 、 数 据 通信 的 基本 概念 、 数 据 传输 类 型 、 数 据 传输 方式 、 数 
据 传输 模式 、 数 据 通 信 方 向 等 ， 在 下 节 将 介绍 一 些 物理 层 中 的 主要 技 
术 ， 如 信道 复 用 方式 、 数 子 编码 方式 、 数 子 调制 技术 等 。 


4.2.1 通信 子 网 与 货源 于 网 


我 们 在 第 2 章 学 习 计算 机 网 络 发 展 历 史 时 已 了 解 到 ， 在 第 二 代 计 算 
机 网 络 时 期 的 APPANET 网 络 中 束 已 把 计算 机 网 络 划 分 成 两 层 结构 ， 那 
环 是 通信 子 网 和 资源 子 网 ， 如 图 4-5 所 示 。 在 后 面 虽然 有 了 各 种 更 加 详 
细 的 分 层 结构 ， 但 是 束 整 个 计算 机 网 络 而 言 ， 仍 可 以 从 大 的 方 同 上 划 


分 这 两 层 。 


计算 机 主机 通信 控制 处 理 机 “计算 机 终端 


图 4-5 通信 子 网 与 资源 子 网 示例 


资源 子 网 是 由 计算 机 系统 、 终 端 系 统 、 连 网 的 外 围 设备 、 各 种 软 
件 资源 与 信息 资源 组 成 。 资 源 子 网 主要 负责 全 网 的 数据 处 理 业务 ， 疝 
网 络 用 户 提 供 各 种 网 络 资源 和 网 络 服务 。 对 于 局 域 网 来 说 ， 痪 源 子 网 
由 连 网 的 服务 器 、 工 作 站 、 共 至 的 打印 机 和 其 他 外 围 设备 、 相 关 软 件 
系统 组 成 ， 对 于 广域网 而 言 ， 资 源 子 网 由 网 上 的 所 有 主机 及 其 外 围 设 
备 组 成 。 资 源 子 网 拥有 所 有 的 共享 资源 及 所 有 的 数据 。 


通信 子 网 负责 网 络 通信 线路 建立 和 通信 处 理 ， 为 网 络 用 户 提供 数 
据 传 葵 、 转 发 、 加 工 和 转换 等 通信 处 理工 作 ， 且 整个 网 络 数 据 通 信 的 
基础 结构 。 对 于 局 域 网 来 说 ， 通 信子 网 由 网 卡 、 线 统 、 集 线 事 、 中 继 
鲁 、 网 桥 、 路由器、 交换 机 等 设备 和 相关 软件 组 成 ， 而 对 于 广域网 来 
说 ， 通 信子 网 由 一 些 专 用 的 通信 处 理 机 (如 结 点 交换 机 、 路 由 器 ) 及 
其 运行 的 软件 和 连接 这 些 节 点 的 通信 链 路 组 成 〈 它 们 共同 组 成 一 个 完 
整 的 通信 线路 ) 。 


通信 子 网 又 可 分 为 点 -点 通信 线路 通信 子 网 与 广播 信道 通信 子 网 两 
类 。 广 域 网 主要 采用 点 到 点 通信 线路 ， 局 域 网 与 城 域 网 一 般 采 用 广播 
信道 。 由 于 技术 上 存在 较 大 的 差异 ， 因 此 在 物理 层 和 数据 链 路 层 协 议 
上 出 现 了 两 个 分 文 : 一 类 是 基于 点- 扩 通 信 线 路 的 ， 男 一 类 是 基于 广播 
言 道 的 。 基 于 点 -点 通信 线路 的 广 域 物理 层 和 数据 链 路 层 扩 术 与 协议 的 
研究 开展 得 比较 早 ， 形 成 了 目 己 的 体系 、 协 议 与 标准 。 而 基于 广播 信 
道 的 局 域 网 、 城 域 网 的 物理 层 和 数据 链 路 层 协议 的 研究 开展 得 相对 比 
较 晚 。 


4.2.2 ”数据 通信 系统 基本 模型 


数据 通信 和 是 计算 机 与 计算 机 或 计算 机 与 终端 之 间 的 通信 。 它 传送 
数据 的 目的 不 仅 是 为 了 交换 数据 ， 更 主要 是 为 了 利用 计算 机 来 处 理 数 
据 。 可 以 说 它 将 快速 传输 数据 的 通信 技术 和 数据 处 理 、 加 工 及 存储 的 
计算 机 技术 结合 了 起 来 ， 从 而 给 用 户 提 供 及 时 准确 的 数据 。 


在 计算 机 网 络 数据 通信 模型 中 ， 涉 及 两 个 实体 ( 源 系统 、 目 的 系 
统 ) 和 一 个 通信 信道 (传输 系统 ) 。 其 中 产 系 统 又 包括 源 站 点 、 发 送 
二 ， 目 的 系统 又 包括 目的 站 点 和 接收 货 。 几 4-6 显 示 了 计算 机 网 络 数据 
通信 系统 基本 模型 组 成 ， 同 时 以 一 个 最 简单 、 最 典型 的 Modem 通 过 
PSTN (公共 交换 电话 网 络 ) 拨号 远程 访问 计算 机 为 例 ， 解 释 了 这 几 个 
组 成 部 分 的 基本 作用 。 


发 送 器 : 传输 系统 [一 接收 器 目的 站 点 


< 源 系统 一 一 传输 系统 一 ”< 一 目的 系统 


轩 数字 信号 模拟 信号 Es | 
图 4-6 数据 通信 系统 基本 模型 


1. 源 系统 


“ 源 系统 "就 是 发 送信 号 的 一 端 ， 即 发 送 方 。 它 包括 以 下 两 个 必需 


[分 ， 


了 时 


口 源 站 点 : 产生 要 传输 的 数据 的 计算 机 或 服务 羽 等 终端 设备 。 


口 发 送 紫 :对 要 传送 的 数据 进行 编码 或 者 调制 的 设备 ， 如 各 种 调 
制 解 调 硼 、 计 算 机 网 卡 。 


2. 传 输 系 统 


“传输 系统 "是 计 算 机 网 络 上 的 数据 传输 通道 ， 除 了 源 系统 和 目的 
系统 外 ， 网 络 中 的 其 他 部 分 都 属于 传输 系统 ， 包 括 通过 物理 层 传输 介 
质 和 相关 协议 建立 的 通信 链 路 ， 以 及 结 点 设备 ， 如 线路 上 的 交换 机 、 
路 由 紫 等 设备 。 这 部 分 是 整个 计算 机 网 络 中 最 复杂 的 一 部 分 ， 不 仅 网 
络 结构 千 关 万 别 ， 而 且 网 络 通信 协议 和 网 络 功能 也 是 各 种 各 样 。 


3.: 目 的 系 贷 


目的 系统 束 古 接收 发 送 端 所 发 送信 号 的 一 疾 ， 即 接收 方 。 与 “ 源 系 
统 ” 一 样 ， 它 也 包括 两 个 必需 的 部 分 : 


口 目 的 站 点 : 从 接收 瑚 获取 从 发 送 端 发 来 的 数据 的 计算 机 或 服务 


日 日 全 


絮 等 。 


口 接收 夯 : 接收 从 发 送 端 发 来 的 信息 ， 并 把 它们 转换 为 能 被 目的 
站 点 设备 识别 和 处 理 的 信息 。 主 要 也 是 各 种 调制 解 调 器 和 网 卡 。 


4.2.3 ”数据 通信 的 几 个 基本 概念 


在 计算 机 网 络 的 数据 通信 中 ， 信 息 、 数 据 、 信 和 号 和 信道 是 四 个 最 
基本 的 概念 。 正 确 理解 这 四 个 概念 ， 对 于 理解 数据 通信 和 原理 是 非常 重 
要 和 必要 的 。 


1. 信 息 (Information) 


通信 的 目的 是 交换 “信息 *”。“ 信 息 ” 是 计算 机 网 络 中 进行 交换 的 一 切 
原始 内 容 的 统称 ， 可 以 是 一 串 串 的 数字 ， 也 可 以 是 各 种 文字 ， 还 可 以 
是 多 媒体 的 图 形 、 图 像 和 语音 。 一 般 是 字母 、 数 字 、 语 音 、 图 形 或 图 
像 的 组 合 。 但 是 我 们 知道 ， 在 计算 机 网 络 中 传输 的 只 能 是 二 进 制 的 数 
据 ， 所 以 为 了 传输 这 些 信 息 ， 首 先 需要 将 各 个 字母 、 数 字 、 语 音 、 图 
形 或 图 像 用 二 进 制 代码 来 表示 ， 这 就 是 我 们 通常 所 说 的 “信息 编码 ”。 
在 信息 编码 标准 中 ，ASCI (American Standard Code for Information 
Interchange， 美 国信 息 交 换 标准 代码 ) 编码 被 国际 标准 化 组 织 接受 ， 成 
为 国际 标准 ISO646， 又 称 为 国际 5 号 码 。 它 既 可 用 做 计算 机 内 部 编码 ， 
也 可 用 做 数据 通信 中 的 编码 标准 。 


在 ASCII 码 标准 中 规定 ， 一 个 字 万 为 8 位 二 进 制 ， 一 个 ASCII 码 占 一 
个 字 节 的 低 7 位 ， 最 高 位 为 校 验 位 (用 于 传输 过 程 检验 数据 正确 性 ) 。 
因为 ASCII 码 用 低 7 位 二 进 制 数 表 示 一 个 字符 ， 故 这 样 一 个 字 蔬 可 表示 2 


的 7 次 方 ， 即 128 种 状态 (从 00000000~01111111) 。 每 种 状态 与 一 个 
ASCII 码 字符 唯一 对 应 ， 这 样 一 来 ， 一 个 字 节 可 以 表示 128 个 字符 ， 其 
中 包括 26 个 英文 大 写字 符 、26 个 英文 小 写字 符 、10 个 数字 字符 、33 个 
标点 符号 和 33 个 控制 符 。 例 如 大 写 英 文字 母 A 的 ASCII 码 是 65， 小 写 英 
文字 母 a 则 是 97。 为 便于 书写 和 记忆 ， 有 时 也 将 ASCI 写 作 十 六 进 制 形 
式 〈 一 个 字 节 恰好 可 以 表示 两 个 十 六 进 制 ) ， 即 将 某 字 符 的 ASCII 码 二 
进 制 数 形式 转换 成 十 六 进 制 数 的 形式 ， 再 标 以 H 表 示 这 是 一 个 十 六 进 制 
的 数 。 例 如 字母 A 的 ASCII 码 为 01000001， 写 成 十 六 进 制 即 41H; 字母 C 
的 ASCII 码 为 01000011， 写 成 十 六 进 制 即 43H 。 


以 上 128 个 字符 的 编码 规则 如 图 4-7 所 示 。 例 如 大 写字 母 C 的 ASCII 
码 ， 只 需 在 图 中 对 应 于 字符 C 的 位 置 ， 找 出 其 横 坐 标 De Ds D4， 《代表 第 
7 位 到 第 5 位 的 最 高 三 位 ， 注 意 最 低位 是 D0) 和 纵 坐 标 Ds D, D; Do。， 依 
次 按 De Ds D4 Ds D, D1 Do 的 顺序 排列 出 来 ， 再 在 最 高 位 补 0， 即 得 到 C 
的 ASCII 码 01000011。 


ee 
uu 
J 

er 
he 


DIE | SP | 
DLL 
| 
_DC3 | # | 
Deca | | 
NAK | % | 
EL 
_ET™B | 
了 ) 
| SB | * | 
RE | 
本 : 汪 本 2 
二 | 
| 


| 


图 4-7 ASCII 码 编码 图 


2. 数 据 (Data) 


“数据 "其实 是 上 面 介绍 的 “信息 ”的 具体 表示 形式 (任何 要 交换 的 信 
县 最 终 都 要 以 一 个 个 具体 的 数据 来 传输 ) ， 征 许多 信息 通过 某 种 方式 
组 成 的 集合 体 。 


数据 有 模拟 数据 和 数 子 数据 之 分 。 模 拟 数据 是 通过 连续 取 值 得 到 
的 数据 ， 如 我 们 打 电 话 时 的 通话 语 首 ， 还 有 以 前 经 常 看 到 的 模拟 电 
影 、 模 拟 电视 所 用 的 数据 都 是 属于 模拟 数据 。 而 “数字 数据 ?是 把 模拟 
数据 离散 、 量 化 为 二 进 制 方式 时 取得 的 数据 ， 如 我 们 存放 在 计算 机 中 


的 所 的 文件 、 图 片 、 图 像 和 软件 等 ， 以 及 我 们 现在 经 党 看 到 的 数字 语 
首 、 数 字 电 影 、 数 字 电 视 等 所 用 的 数据 都 属于 数 子 数据 。 在 计算 机 磁 
盘 中 存放 在 的 必须 是 数字 数据 ， 而 模拟 数据 通常 存 放 在 位 市 、 胶 市 
- 


模拟 数据 是 时 间 的 函数 ， 并 占有 一 定 的 频率 范围 ， 即 频 市 。 模 拟 
数据 也 可 以 用 数字 信号 来 表示 ， 那 惑 是 模拟 信号 的 数字 编码 。 对 于 声 
音 数据 来 说 ， 完 成 模拟 数据 和 数字 信和 号 转换 功能 的 设施 是 编码 解码 融 
(CODEC) 。 编 码 解码 器 将 直接 表示 声音 数据 的 模拟 信号 编码 转换 成 
二 进 制 流 近似 表示 的 数 子 信号， 在 线路 为 一 端的 编码 解码 器 则 将 二 进 
制 流 码 恢复 成 原来 的 模拟 数据 。 数 字 电 话 通信 和 是 它 的 一 个 应 用 模型 。 


数字 数据 可 以 转换 成 模拟 信号 ， 如 Modem 可 以 把 数字 数据 调制 成 
模拟 信号 ; 也 可 以 把 模拟 信号 解 调 成 数字 数据 。 用 Modem 拨 号 上 网 束 
征 现 实 中 这 一 互 换 过 程 的 应 用 模型 。 


“模拟 数据 ?的 大 小 一 般 是 以 时 长 为 依据 的 ， 而 “数字 数据 ?是 以 各 种 
容量 为 单位 的 。 数 字数 据 的 单位 主要 有 如 下 几 种 : 位 (bit， 比 特 ， 指 
一 个 二 进 制 的 0 或 1) 、 字 节 (B，1B=8bit) ， 而 且 1KB=1024B; 
1MB=1024KB; 1GB=1024MB 。 


3. 信 号 (Signal) 


“信和 号 ?是 “数据 ”在 传输 过 程 中 电信 和 号 或 光 信 和 号 的 表示 形式 ， 

为 “数据 ”有 “模拟 数据 ?和 “数字 数据 ”两 种 类 型 ， 所 以 信号 也 有 “模拟 信 

号 ?和 “数字 信和 号 ?两 种 。“ 模 拟 信号 ” (analog signal) 是 “模拟 数据 ”的 电 
平 信号 表示 形式 ， 其 信号 电 平 是 一 个 随时 间 连 续 变 化 的 (中间 没 有 跳 

跃 ) 函数 曲线 (每 个 周期 的 曲线 是 一 样 的 ， 如 图 4-8 所 示 。 而 “数字 信 
号 ”(digital signal) 是 “数字 数据 ”的 信号 电 平 表示 形式 (由 一 个 个 “ 码 

元 ”组 成 ， 一 个 “ 码 元 ”就 包括 一 个 脉冲 周期 ， 用 两 种 不 同 的 电 平 表示 
二 进 制 的 0 和 1 信号 所 对 应 的 电压 脉冲 ， 是 离散 ( 非 连 续 变 化 ) 的 ， 如 

图 4-9 所 示 。 


V (1) 


-个 周期 


图 4-8 模拟 信号 波形 


V (1) 


图 4-9 数字 信号 波形 


“信道 ”就 是 通信 双方 物理 链 路 (包括 有 线 物 理 介质 上 的 链 路 和 无 
线 介质 上 的 链 路 上 通过 物理 层 协议 建立 起 来 的 数据 传输 通道 。 默 认 
情况 下 ， 一 条 传输 介质 束 一 条 信道 ， 也 融 是 同一 时 刻 只 有 一 路 通信 。 
距 像 早期 的 公路 ， 既 不 划分 车 道 ， 也 不 划分 通行 方向 ， 一 条 大 路 任 由 
行人 和 竹 辆 对 哪 个 方 癌 通过 。 但 目前 在 广域网 中 ， 通 利 是 采用 “信道 复 
用 ”技术 实现 在 一 条 介质 上 划分 多 个 信道 ， 以 实现 同时 多 路 、 不 同方 同 
的 通信 (如 图 4-10 所 示 ) ， 信 道 的 具体 复 用 原理 将 在 本 章 后 面 介绍 。 


一 物理 链 路 


图 4-10 传输 媒介 中 的 信道 


4.2.4 数据 传输 类 型 


数据 通信 的 任务 是 准确 迅速 地 传递 信息 。 信 源 信号 (也 就 是 信号 
源 发 送 的 信号 ) 经 过 信 源 编码 之 后 成 为 离散 的 二 进 制 数字 信号 。 我 们 
用 一 些 离散 的 波形 来 代 奉 这 些 数 字 信 和 号。 这些 离 散 的 信号 可 以 直接 进 
行 传输 ， 或 者 调制 到 载波 上 进行 传输 。 这 样 束 形成 了 两 种 最 基本 的 数 
字 信 和 号 的 传输 类 型 一 一 基 囊 传输 和 频 市 传输 。 在 频 市 传输 基础 上 ， 通 
过 信道 的 复 用 又 诞生 了 一 种 称 为 宽带 传输 的 数据 传输 类 型 。 


1. 基 市 与 频 市 


要 理解 什么 是 荐 传输 和 频 市 传输 ， 首 移 要 理解 什么 是 基带 〈base 
band) 和 频带 (frequency band) 。 基 带 是 指 信 源 发 出 的 ， 没 有 经 过 调 
制 “进行 频谱 搬移 和 变换 ) 的 原始 电信 号 所 固有 的 频带 《频率 市 
宽 ) ， 也 称 为 基本 频 市 。 而 频带 是 指 对 基带 信号 调制 后 所 占用 的 频率 
带 视 (一 个 信号 所 占有 的 从 最 高 的 频率 到 最 低 的 频率 之 差 )。 有 关 调 
制 技术 和 原理 将 在 本 章 后 面具 体 介绍 。 


信 源 发 出 的 没有 经 过 调制 的 原始 电信 号 ( 原 汁 原味) 就 称 为 基 市 


信号 。 基 市 信号 的 特点 是 频率 较 低 ， 信 和 号 频 谐 征 从 零 频 率 的 直流 成 分 


开始 的 。 如 琳 一 个 信号 包 


全 
流 成 分 ， 则 这 个 信号 就 是 基 


经 过 调制 后 的 基 市 信号 称 为 频 市 信号 。 频 市 信号 的 频率 被 限制 在 
一 个 特定 的 频带 中 。 如 来 一 个 信号 只 包含 了 一 种 频率 的 交流 成 分 ， 或 
者 有 限 几 种 频率 的 交流 成 分 ， 我 们 束 称 这 种 信号 为 频 市 信号 。 根 据 原 
台电 信号 的 特征 ， 基 融 (或 频带 ) 信号 可 分 为 数字 基带 (或 频带 ) 信 
号 和 模拟 基带 (或 频带 ) 信号 (相应 的 ， 信 源 也 分 为 数字 信 源 和 模拟 
信 源 ) ， 具 体 由 其 信 源 类 型 确定 。 数 字 基 带 信 和 号 往往 包含 丰富 的 低频 
分 量 ， 甚 至 直流 分 量 。 在 某 些 具有 低 通 特性 的 有 线 信 道中 ， 特 别 是 传 
输 距 离 不 太 远 的 情况 下 ， 数 字 基 珊 信 号 可 以 直接 传输 。 


~ 


3. 基 市 传输 和 频 市 传输 


通过 对 以 上 基 市 信号 和 频 市 信号 定义 的 了 解 ， 我 们 很 容易 知道 ， 
在 信道 中 直接 传输 基 珊 信号 的 方式 称 为 基 市 传输 ， 而 在 信道 中 传输 频 
市 信号 的 方式 称 为 频 市 传输 。 


在 基 市 传输 中 ， 由 于 不 调制 ， 所 以 整个 信道 只 传输 一 种 信和 号 
信 信 道 利用 率 低 。 在 基带 传输 中 ， 需 要 在 信 源 端 对 数字 信号 进行 编 
码 ， 在 信 答 端 对 编码 的 数据 进行 解码 恢复 ， 这 分 别 是 由 编码 侨 和 解码 
器 完成 的 。 由 于 在 近 距 离 传输 范围 内 基带 信和 号 的 衰减 不 大 ， 从 而 信和 号 


内 容 不 会 发 生变 化 。 因 此 在 传输 距离 较 近 时 ， 计 算 机 网 络 都 采用 基带 
传输 类 型 。 大 多 数 的 局 域 网 使 用 基 市 传输 ， 如 以 太 网 、 令 牌 环 网 等 。 


而 频 市 传输 广泛 应 用 于 广域网 中 ， 因 为 在 这 种 网 络 通信 中 ， 往 往 
需要 同时 发 送 多 种 信号 《如 数据 信号 、 路 由 信号 ， 以 及 各 种 网 络 控制 
信号 ) ， 这 时 就 可 以 利用 高 频率 的 信号 来 调制 低频 率 信和 号， 以 实现 同 
步 传输 ， 也 提高 了 信道 利用 率 。 由 于 频带 传输 中 所 用 的 传输 频率 通常 
比较 高 ， 所 以 也 适用 于 远 距离 的 广域网 通信 。 有 关 信 号 调制 将 在 本 章 
后 面具 体 介 绍 。 


4. 基 市 传输 系统 和 频 市 效 字 传输 系统 


要 进行 基 市 传输 ， 必 须 有 一 整套 基 市 传输 系统 。 图 4-11 所 示 的 古 数 
字 基 市 传输 系统 的 基本 结构 ， 主 要 由 编码 旧 、 发 送 闹 低 通 滤波 右 、 传 
输 信 道 、 接 收 闹 低 通 滤波 器 、 采 样 判 决 器 和 解码 右 组 成 。 此 外 为 了 保 
证 系统 可 靠 有 序 地 工作 ， 还 应 有 位 同步 系统 。 


编码 器 


位 同步 器 


图 4-11 数字 基 市 传输 系统 基本 结构 


图 4-11 中 所 示 各 组 成 部 分 的 解释 如 下 : 


口 编码 器 : 将 信 源 或 信 源 编码 输出 的 编码 类 型 (通常 为 单 极 性 不 
归 零 码 NRZ) 变 为 适合 于 信道 传输 的 码 型 。 有 关 基 带 信号 的 编码 类 型 
将 在 本 章 后 面 专门 介绍 。 


口 发 送 端 低 通 滤波 器 :将 编码 之 后 的 基带 信号 变换 成 适合 于 信道 
传输 的 基带 信号 ， 这 种 变换 主要 是 通过 波形 变换 来 实现 的 ， 其 目的 是 
使 信号 波形 与 信道 匹配 ， 便 于 传输 ， 减 小 码 间 串 扰 ， 利 于 同步 提取 和 
采样 判决 。 


口传 输 信 道 : 它 征 允许 基 融 信号 通过 的 传输 介质 ， 如 双 绞 线 、 电 
绕 线 等 。 信 道 的 传输 特性 通 向 不 满足 无 失真 传输 条 件 ， 甚 至 古 随 机 变 
化 的 ， 还 会 额外 引入 噪声 。 


口 接收 端 低 通 滤波 器 : 滤 除 带 (基本 频带 信号 ) 外 噪声 ， 并 对 信 
道 特性 均衡 ， 使 输出 的 基 市 波形 无 码 间 串扰 ， 有 利于 下 面 的 采样 判 
人 


口 采样 判决 器 :在 传输 特性 不 理想 或 存在 噪声 的 背景 下 ， 在 规定 
的 时 刻 (由 位 定时 脉 促 控 制 ) 对 从 接收 端 滤波 器 输出 的 波形 进行 采 
样 ， 以 恢复 或 再 生 基 珊 信号 。 


口 解码 紫 :， 对 采样 判决 右 输 出 的 信号 进行 解码 ， 还 原 有 用 的 输入 
言 号 ， 并 使 输出 码 型 符合 接收 终端 的 要 求 。 


口 位 同步 大 : 提取 位 同步 信号 ， 通 过 同步 信号 控制 采样 判决 着 ， 
再 生 数 字 基 市 信号 。 


同样 ， 要 进行 频 市 传输 ， 也 必须 有 一 人 整 父 频 市 传输 系统 。 在 前 面 
介绍 的 数字 基 市 传输 系统 中 ， 为 使 数字 基 市 信号 能 够 在 信道 中 传输 ， 
要 求 信道 应 具有 低 通 (也 避 ® 是 所 有 低 于 某 个 频率 的 信号 均 可 通过 ， 高 
于 某 个 频率 的 信号 全 部 滤 除 ) 形式 的 传输 特性 。 而 大 多 数 实际 信道 具 
有 市 通 (也 束 古 只 有 频率 在 某 个 范围 内 的 信号 才能 通过 ， 其 他 的 均 将 
滤 除 ) 传输 特性 ， 基 带 信和 号 不 能 在 这 种 带 通 传输 特性 的 信道 中 传输 ， 
必须 进行 调制 。 调 制 就 是 把 一 个 调制 信号 放 在 男 一 个 频率 更 高 的 载波 
言 号 上 ， 使 在 信道 中 传输 的 信号 具有 两 种 信号 波 的 双重 特性 ， 然 后 通 
过 调制 信号 的 某 些 特性 (如 振幅 、 相 位 ， 影响 载波 信号 相应 特性 的 一 
种 技术 。 


数字 频 市 传输 系统 与 数字 基 囊 传输 系统 的 结构 基本 类 似 ， 不 同 的 
只 是 在 频 市 传输 系统 的 接收 问 要 采用 “调制 右 ?" 敬 代 基 市 传输 系统 
的 “编码 仑 ”>， 采 用 “发 送 凯 市 通 滤波 右 ? 警 代 基 市 传输 系统 中 的 “发 送 站 
低 通 滤波 郁 "”， 在 频 市 传输 系统 的 接收 闪 要 采用 " 解 调 着 "区 代 基 市 传输 
系统 中 的 “解码 郁 ”， 采 用 “接收 端 市 通 沽 波 郁 ? 迄 代 基 市 传输 系统 
的 “接收 喘 低 通 滤 波 絮 ”"， 如 图 4-12 所 示 。 


接收 端 带 采样 判 
通 滤波 器 决 融 


图 4-12 数字 频 市 传输 系统 的 基本 结构 


数字 频 市 传输 系统 是 发 送 端 含有 调制 贷 ， 接 收 疹 含 有 解 调 夯 的 数 
通信 系统 。 数 字 调 制 是 用 数字 基带 信和 号 改变 高 频 载 波 的 参数 ， 实 现 
带 信号 变换 为 频带 信号 的 过 程 ， 此 过 程 中 信和 号 频谱 由 原来 的 低频 信 
号 搬移 到 高 频段 。 数 字 解 调 是 把 数字 频带 信号 恢复 成 原来 数字 基带 信 
号 的 过 程 ， 此 信和 号 中 的 频谱 由 高 频段 恢复 到 原来 的 基带 信号 的 低频 


段 。 


由 于 基 市 传输 的 信号 频率 通 币 较 低 ， 为 了 能 传输 更 远 距 离 ， 抵 抗 
外 界 干扰 ， 在 复 洒 的 网 络 环境 和 远 距 离 传输 中 ， 通 常 不 采用 基 市 信 
号 ， 而 是 把 发 送 端 发 出 的 原始 信号 经 过 调制 ， 附 加 在 一 些 高 频率 的 载 
流 上 进行 传输 。 这 种 频带 传输 不 仅 克 服 了 目前 许多 长 途 通 信 线 路 中 不 
能 直接 传输 基带 信和 号 的 缺点 ， 而 且 能 实现 多 路 复 用 的 目的 ， 从 而 提高 
通信 线路 的 利用 率 。 


5. 宽 市 传输 和 视 市 传输 系统 


所 谓 “ 宽 带 ” (Broadband) 就 是 采用 比 音频 (4kHz) 更 宽 的 频带 ， 
该 频带 包括 了 大 部 分 电磁 波 频 谱 ， 是 相对 前 面 的 “频带 ”来 说 的 ， 


为 “ 频 市 ?只 具有 有 限 的 频率 宽度 。 使 用 这 种 视频 带 进行 的 数据 传输 残 
称 为 宽带 传输 。 宽 市 传输 其 实 与 频带 传输 具有 相同 的 特点 ， 它 也 需要 
对 信 源 发 出 的 原始 信号 进行 调制 ， 但 它 将 一 个 信道 分 成 多 个 于 信道 ， 

分 别传 送 音频 、 视 频 和 数字 信号 ， 而 且 宽 带 传输 中 的 所 有 子 信道 都 可 
以 同时 发 送信 号 。 宽 市 传输 一 定 是 采用 频 市 传输 技术 的 ， 但 频 市 传输 


不 一 定 束 是 宽 市 传输 。 


最 常见 的 宽带 传输 就 是 我 们 天 天 用 的 有 线 电 视 ， 在 一 根 同 轴 电 统 
中 可 以 传输 那么 多 电视 频道 。 还 有 无 线 广播 也 是 采用 宽带 传输 的 。 宽 
带 通 常 是 传输 模拟 信号 的 ， 数 据 传输 速率 范围 为 0~400Mbps， 而 通常 使 
用 的 传输 速率 是 5~10Mbps。 


各 子 信道 的 宽 市 传输 系统 结构 与 前 面 介 绍 的 频带 传输 系统 结构 基 
本 一 样 。 


4.2.5 数据 传输 方式 

计算 机 网 络 数据 通信 的 数据 传输 方式 可 分 “ 串 行 传输 > 和 “并 行 传 
输 * 两 种 。 

(1) 串 行 传输 

“ 串 行 传输 ” 指 的 是 数据 流 以 捉 行 方式 一 位 位 地 在 一 条 信道 上 传 
输 。 如 一 个 字符 的 8 个 二 进 制 代 码 ， 需 要 由 高 位 到 低位 顺序 排列 依次 传 


输 ， 如 图 4-13 所 示 。 等 第 一 个 字符 的 最 高 位 传输 完 后 ， 再 传输 第 二 个 字 
符 的 最 低位 ， 依 此 类 推 ， 这 样 串 接 起 来 形成 串 行 数据 流 。 


wwTwTeTeTw 
-| 接收 方 


数据 比特 流 一 位 位 地 依次 传输 


图 4-13 串 行 数据 传输 原理 示例 


很 显然 ， 串 行 传输 只 需要 一 条 传输 信道 (当然 在 一 个 接口 中 可 以 
有 多 条 这 样 的 串 行 传输 信道 ) ， 传 输 速度 比较 慢 ， 但 易于 实现 、 费 用 
低 ， 是 目前 主要 采用 的 一 种 传输 方式 。 男 外 ， 串 行 传输 存在 一 个 收 、 
发 双方 如 何 保持 码 组 或 者 说 字符 同步 〈 也 吏 是 如 果 识 别 一 个 字符 包括 
哪 几 个 比特 位 ) 的 问题 。 这 个 问题 不 解决 ， 接 收 方丈 不 能 从 接收 到 的 
数据 流 中 正确 地 区 分 出 一 个 个 字符 来 ， 因 而 传输 将 失去 意义 。 如 何 解 


决 码 组 或 子 符 同步 的 问题 ， 束 涉及 本 市 后 面 将 要 介绍 的 异步 传输 方式 
和 同步 传输 方式 了 。 


采用 串 行 传输 方式 的 典型 代表 有 计算 机 串 行 接 口 (简称 串口 ， 对 
应 RS-232C 标 准 ) ， 还 有 如 USB 接 口 、SATA 〈 串 行 AITA) 磁盘 接口 
等 ， 它 们 在 传输 数据 时 都 是 一 位 位 地 进行 串 行 传输 的 。 


(2) 并 行 传输 


“并 行 传输 ” 指 的 十 数据 以 一 组 或 者 整个 字符 的 方式 在 多 条 并 行 信 
道上 同时 传输 。 音 用 的 就 是 将 构成 一 个 字符 代码 的 8 位 二 进 制 码 ， 分 别 
在 8 个 并 行 信道 上 进行 传输 ， 如 图 4-14 所 示 。 由 于 同一 时 刻 多 条 信道 上 
同时 传送 了 整个 字符 的 所 有 比特 位 ， 所 以 收 、 发 双方 不 存在 字符 的 同 
步 问题 ， 这 二 并 行 传输 的 一 个 主要 优点 。 但 是 ， 并 行 传输 必须 有 并 行 
信道 ， 这 往往 带 来 了 设备 上 或 实施 条 件 上 的 限制 ， 一 般 适 用 于 计算 机 
和 其 他 高 速 数据 系统 的 近 距 离 传 输 。 


-个 字符 的 8 个 比特 位 同时 传输 
| 六 | 一 接收 广 


图 4-14 并 行 数据 传输 原理 示例 


采用 并 行 传输 方式 的 典型 代表 有 计算 机 上 连接 打印 机 的 并 口 、 磁 
盘 ATA (或 者 IDE) 接口 等 ,计算 机 主板 上 CPU 与 其 他 芯片 的 数据 传输 
也 是 采用 并 行 传输 方式 。 


4.2.6 ”数据 传输 模式 


在 本 广 前 面 介绍 串 行 传输 方式 时 束 已 说 到 ， 串 行 传输 接收 并 存在 
一 个 如 何 从 串 行 数据 比特 流 中 正确 地 划分 出 发 送 的 一 个 个 字符 的 问 
题 ， 也 承 是 字符 同步 的 问题 。 在 串 行 数据 通信 中 同步 问题 十 分 关键。 
发 送 端 一 位 一 位 地 把 信息 通过 介质 发 往 接收 端 ， 接 收 端 必须 识别 信息 
的 开始 和 结束 ， 而 且 必 须知 道 每 一 位 的 持续 时 间 。 只 有 这 样 ， 搂 收 端 
才能 从 传输 线路 上 正确 地 取出 被 传送 的 数据 。 根 据 实现 字符 同步 的 方 
式 不 同 ， 有 同步 传输 (Synchronous Transmission) 和 异步 传输 
Asynchronous Transmission) 两 种 方式 。 所 以 这 里 所 讲 的 同步 传输 和 
异步 传输 都 是 针对 串 行 传输 模式 而 言 的 ， 并 行 传输 模式 中 不 涉及 同步 
问题 ， 因 为 并 行 传输 中 一 次 就 可 以 传输 整个 字符 。 


1. 同 步 传输 


同步 传输 中 关键 是 要 理解 “同步 ”的 含义 。 同 步 就 古 指 通信 双方 在 
传输 过 程 中 古 同 步 进 行 的 (也 就 古 接收 端 与 发 送 端 同时 开始 工作 ， 并 
且 接 收 端 按 数 据 的 发 送 顺序 进行 接收 ) ， 同 步 的 依据 束 是 双方 有 相同 
的 时 钟 参 考 ， 能 同时 开始 数据 的 发 送 和 接收 。 通 常 这 个 时 钟 参考 是 同 
步 时 钟 线 或 同一 个 时 钟 产 。 


同步 传输 是 一 种 以 数据 块 为 传输 单位 (通常 是 以 “ 帧 ”为 单位 
的 ) ， 以 相同 的 时 钟 参考 进行 数据 传输 的 模式 ， 因 此 又 称 为 区 块 伟 
输 。 在 该 传输 模式 下 ， 每 一 比特 数据 的 持续 传输 时 间 都 是 相等 的 ， 而 
且 在 每 个 字符 的 传输 过 程 中 ， 两 个 字符 间 传 输 所 需 等 待 的 时 间 也 十 相 
同 的 。 


另外 ， 在 同步 传输 中 的 数据 块 的 开始 和 结尾 部 分 都 有 一 个 用 于 数 
据 帧 同步 的 特殊 字符 、 竺 定 的 字 世 或 特定 的 帧 ， 这 具体 要 视 所 采用 的 
同步 方法 而 定 。 同 步 传输 分 为 面 癌 字符 的 同步 传输 、 面 癌 比 特 的 同步 
传输 和 面 癌 字 万 的 同步 传输 等 儿 种 。 面 癌 字 符 的 同步 传输 中 ， 每 个 数 
据 块 的 第 一 部 分 包含 一 组 同步 字符 《一般 是 1~2 字 节 ， 有 是 一 个 独特 的 比 
特 组 合 ， 相 当 于 数据 帧 的 “起 始 位 >) ， 用 于 通知 接收 方 一 个 帧 已 经 到 
达 。 它 同时 还 能 确保 接收 方 的 采样 速度 和 比特 的 到 达 速度 保持 一 致 ， 
使 收 、 发 双方 进入 同步 。 在 传送 完 一 个 数据 帧 的 最 后 一 部 分 包含 一 个 
帧 结束 标记 ( 称 为 区 块 结束 字符 ,一般 是 1 字 市 ， 也 是 一 个 独特 的 比特 
串 ， 相 当 于 数据 帧 的 “停止 位 *”) ， 用 于 表示 在 下 一 帧 开始 之 前 没有 别 
的 即将 到 达 的 数据 了 。 男 外 ， 一 般 还 要 附加 一 个 校 验 序列 ( 称 为 区 块 
校 验 字符 ， 一 般 也 是 1 字 广 ) ， 以 便 对 数据 块 进行 差错 控制 。 同 步 传 输 
模式 中 ， 数 据 帆 格式 如 图 4-15 所 示 。 因 为 涉及 “数据 链 路 层 ” 的 幅 同 步 ， 
所 以 具体 将 在 下 章 介绍 。 


数据 块 


( Data Block ) 


一 


图 4-15 同步 传输 数据 帧 格式 


采用 同步 传输 的 技术 代表 有 SDH (Synchronous Digital Hierarchy， 
同步 数字 系列 ) 、STM (Synchronous Transfer Module， 同 步 传输 模 
块 ) 和 HDLC (High level Data Link Control， 高 级 数据 链 路 控制 ) 等 。 


与 下 面 将 要 介绍 的 “异步 传输 ”方式 比较 , “同步 传输 ”在 技术 上 较 复 
杂 ， 但 不 需要 对 每 个 字符 加 单独 的 “起 始 ” 和 "停止 ?比特 ， 接 收 方 不 必 对 
每 个 字符 进行 开始 和 停止 的 操作 ， 只 需要 在 检测 到 帧 同步 字符 时 接收 
它们 即 可 。 而 且 同 步 传 输 是 以 帧 为 传输 单位 (异步 传输 是 以 字符 为 传 
输 单 位 的 ， 一 个 帧 通常 有 500 字 节 ，4000 比 特 ， 进行 传输 的 ， 只 需 在 一 
个 数据 帧 的 前 后 加 上 标志 字符 即 可 ， 因 此 传输 效率 高 ， 常 用 于 较 高 速 
的 数据 传输 。 


2. 异 步 传输 


异步 传输 的 关键 也 是 异步 这 两 个 字 ， 征 指 通信 双方 没有 相同 的 时 
钟 参考 (也 就 是 发 送 端 和 接收 端 不 同时 开始 工作 ) ， 但 双方 在 数据 传 
输 速率 上 有 是 同步 的 。 即 指 每 个 字符 之 间 是 异步 的 ， 但 一 个 字符 内 的 每 
一 位 还 是 同步 的 。 


异步 传输 是 以 字符 为 单位 进行 数据 传输 的 。 在 发 送 每 一 字符 代码 
的 前 面 均 加 上 一 个 起 始 位 "信号 (长度 为 1 比特 ， 极 性 为 0) ， 用 以 标 
记 一 个 字符 的 开始 ， 在 一 个 字符 代码 的 最 后 加 上 一 个 “停止 位 * 信 号 
(长 度 为 1 或 2 比特 ， 极 性 为 ， 用 以 标记 一 个 字符 的 结束 。 字 符 位 占 
5~8 位 ， 具 体 取决 于 数据 所 采用 的 字符 集 ， 如 电报 码 字 符 为 5 位 ，ASCII 
码 字符 为 7 位 。 异 步 传输 时 每 个 字符 的 数据 结构 如 图 4-16 所 示 。 图 4-17 
所 示 是 一 个 异步 传输 模式 的 数据 传输 示例 。 


图 4-16 异步 传输 中 的 数据 格式 
数据 传输 方向 


停止 位 起 始 位 


~ 本 ee- 


传输 间隙 


图 4-17 异步 传输 示例 


异步 传输 的 典型 代表 就 是 ATM (异步 传输 模式 ) 技术 ， 目 前 仍 是 
城 域 网 和 广域网 中 主流 的 交换 技术 之 一 。 早 期 还 有 一 种 B-ISDN 《宽带 
ISDN) 技术 ， 也 是 异步 传输 技术 的 代表 。 


于 < 异步 传输 ”中 ， 发 送 方 可 以 在 任何 时 刻 发 送 这 些 比 特 组 ， 而 接 
收 方 从 不 知道 它们 会 在 什么 时 候 到 达 ， 故 不 需要 同时 开始 接收 。 被 发 
送 的 比特 组 需 进行 排除 等 修 。 最 典型 的 一 个 异步 传输 实例 就 是 我 们 访 
问 互联 网 上 的 网 站 ， 点 击 一 个 网 站 ， 网 站 服务 器 一 般 不 会 马上 响应 ， 
而 是 等 它 有 资源 啊 应 时 才 啊 应 ， 所 以 网 站 打开 时 往往 有 些 延 时 。 


异步 传输 的 优点 是 字符 同步 实现 简单 ， 收 发 双方 的 时 钟 信号 不 需 
要 严格 同步 。 缺 点 是 对 每 一 字符 都 需 加 入 “起 、 止 ” 码 元 ， 使 传输 效率 
降低 。 例 如 假设 每 次 传送 7 比特 的 信息 ， 每 个 字符 需要 另外 加 一 个 起 始 
位 和 一 个 停止 位 。 男 外 ， 异 步 通信 主要 人 处理 ASCII 编 码 的 信息 ， 这 意味 
着 增加 了 第 3 个 控制 位 ， 即 奇偶 校 验 位 ， 这 样 每 个 字符 附加 3 位 控制 
位 ， 传 输 效 率 只 有 70%。 


4.2.7 ”数据 通信 方式 


在 数据 通信 中 ， 按 照 通 信 双 方 的 通信 方式 通信 可 以 分 为 以 下 三 
种 : 单 工 通信 、 半 双 工 通信 、 全 双 工 通信 。 


1. 单 工 通信 


图 4-18a 所 示 为 单 工 通信 方式 。 在 单 工 通信 中 ， 信 号 只 能 同一 个 方 
加 传输， 任何 时 候 都 不 能 改变 信和 号 的 传输 方 癌 。 


c ) 双 工 通信 
图 4-18 三 种 数据 传输 方 同 


“ 单 工 ”( 也 就 是 “ 单 向 工作 ”) 吏 是 指 永远 只 能 往 一 个 方向 传输 数 
据 。 数 据 发 送 方 和 接收 方 部 是 固定 的 。 束 相当 于 我 们 现实 生活 中 所 见 
的 单 向 公路 (通常 是 单车 道 ) 。 单 工 数据 传输 就 相当 于 汽车 在 单 向 车 
道行 驶 ， 如 图 4-19 所 示 。 在 这 样 的 公路 上 ， 车 只 能 按 一 个 方向 行驶 。 很 
显然 ， 这 种 数据 传输 方式 效率 最 低 ， 不 能 满足 我 们 的 数据 通信 和 需 来 ， 
所 以 现在 一 般 不 用 了 。 


车 道 


总 是 朝 一 个 方向 行驶 的 汽车 
图 4-19 单 工 通信 类 比 示 例 
六 竺 双 工 通信 


图 4-18b 所 示 为 半 双 工 通信 方式 。 此 时 信号 可 以 双 同 传送 ， 但 必须 
征 交 替 进 行 ， 同 一 时 间 只 能 同一 个 方 同 传送 。 也 融 是 说 ,“ 半 双 工 ?在 
同一 时 刻 只 能 进行 单 向 数据 传输 ， 但 是 在 不 同时 刻 可 以 进行 妨 一 个 方 
癌 的 数据 传输 。 这 束 相 当 于 双 辣 单车 道 。 在 这 样 的 车 道中 ， 同 一 时 刻 
只 允许 一 个 方 同 的 汽车 通过 ， 只 有 当 为 一 方 同 没 有 车 过 来 的 时 候 ， 才 
能 从 目 己 一 方 发 车 ， 如 图 4-20 所 示 。 它 与 前 面 的 “童工 ”不 一 样 的 束 古 它 


可 以 进行 双 回 数据 通信 ， 只 不 过 两 个 方 癌 不 能 同时 进行 数据 传输 。 半 
双 工 通信 是 目前 网 络 设备 所 文 持 的 最 主要 的 数据 传输 模式 。 
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朝 一 个 方向 行驶 的 汽车 


图 4-20 半 双 工 通信 类 比 示例 
3. 全 双 工 通信 


图 4-18c 所 示 为 全 双 工 通信 方式 。 此 时 信和 号 任何 时 刻 都 可 以 同时 双 
问 传 送 。 它 要 求 至 少 存在 两 条 信道 。 也 就 古 说 ,“ 全 双 工 ”在 同一 时 刻 
可 以 进行 两 个 方向 的 数据 传输 ， 而 且 互 不 影响 。 这 就 相当 于 我 们 现实 
生活 中 的 “ 双 辣 双 车 道 ”。 在 这 样 的 公路 中 ， 两 个 方向 的 汽车 都 可 以 同 
时 通过 ， 如 图 4-21 所 示 。 很 明显 ， 这 样 可 以 提高 汽车 通过 的 效率 。 对 于 
数据 通信 来 说 ， 全 双 工 的 线路 的 传输 速率 就 是 提高 了 数据 传输 速率 ， 


最 高 可 以 达到 带宽 的 两 倍 。 如 100Mbps 的 全 双 工 线路 ， 最 终 的 数据 传输 
速率 最 高 可 达 200Mbps。 这 也 就 是 4 个 100Mbps 端 口 聚合 而 成 的 以 太 网 
通道 ， 最 高 可 以 达到 800Mbps 的 数据 传输 速率 的 原因 了 。 


车 道 1 


车 道 2 


朝 一 个 方向 行驶 的 汽车 
图 4-21 全 双 工 通信 类 比 示例 


一 个 以 太 网 端口 的 工作 模式 有 : 10Mbps 半 双 工 、10Mbps 全 双 工 、 
100Mbps 半 双 工 、100Mbps 全 双 工 、1000Mbps 全 双 工 和 自动 协商 这 么 几 
种 。 当 然 最 终 能 文 持 哪 几 种 ， 要 根据 设备 上 各 问 口 所 文 持 的 网 络 撤 术 
标准 而 定 。 


一 般 来 说 ， 建 议 将 通信 双方 的 端口 工作 模式 设置 一 致 ， 否 则 要 人 么 
出 现 不 能 成 功 连 接 ， 要 入 会 降低 男 一 痢 的 端口 数据 处 理性 能 。 如 一 站 
设置 为 单 工 ， 而 为 一 端 设 置 为 半 双 工 ， 则 最 终 只 能 是 选择 最 低 要 求 的 
半 双 工 模式 进行 通信 。 现 以 普通 的 10/100Mbps 目 适应 快速 以 太 网 端口 
为 例 进行 介绍 ， 具 体 规则 如 下 : 


口 如 果 一 端 是 固定 模式 (无 论 是 10Mbps 还 是 100Mbps) ， 另 外 一 
端 是 自 协 商 模式 ， 即 便 能 够 协商 成 功 ， 自 协商 的 那 一 端 也 只 能 工作 在 
半 双 工 模式 。 


口 如 果 一 端 工作 在 全 双 工 模式 ， 另 外 一 端 工作 在 半 双 工 模式 ( 包 
括 自 协 商 出 来 的 半 双 工 ) ，Ping 是 没有 问题 的 ， 流 量 小 的 时 候 也 没有 任 
何 问 题 ， 流 量 达到 约 15% 以 上 时 ， 束 会 出 现 冲 突 、 错 包 ， 最 终 影响 工作 
性 能 。 


口 对 于 两 端 工 作 模 式 者 是 目 动 协 商 ， 最 后 协商 成 的 结果 是 “两 端 孝 
支持 的 工作 模式 中 优先 级 最 高 的 那 一 类 ”， 通 常 为 半 双 工 模式 优先 。 


口 如 果 A 端 为 自动 协商 模式 ，B 端 设置 为 100Mbps 全 双 工 模式 ， 则 
在 A 协商 为 100Mbps 半 双 工 模式 后 ， 再 强制 将 B 改 为 10Mbps 全 双 工 模 
式 ，A 端 也 会 马上 向 下 协商 到 10Mbps 半 双 工 模式 ;如 果 A 端 为 自动 协商 
模式 ，B 喘 设置 为 10Mbps 全 双 工 模式 ， 则 在 A 协商 为 10Mbps 半 双 工 模 
式 后 ， 再 强制 将 B 改 为 100Mbps 全 双 工 模式 ， 则 会 出 现 协商 不 成 功 ， 连 
接 不 上 的 现象 。 这 个 时 候 ， 如 果 播 拔 一 下 网 线 ， 又 会 重新 协商 为 
100Mbps 半 双 工 模式 。 


4.3 ”数据 传输 速率 与 信道 市 宽 


在 数据 通信 中 ， 数 据 传输 速率 与 信道 带宽 〈 或 称 传输 带宽 ) 是 两 
个 非常 重要 的 概念 。 它 们 定义 了 传输 链 路 上 的 物理 层 基 本 特性 ， 而 且 
两 者 之 间 存 在 一 些 必然 的 联系 ， 本 市 要 详细 介绍 数据 传输 速率 与 信道 
带 冤 的 计算 ， 以 及 它们 之 间 的 关系。 


4.3.1 ”传输 速率 与 信道 市 蜗 的 基本 概念 


在 本 草 前 面 已 介绍 天 了， 传输 速率 是 在 物理 层 的 电气 特性 中 定义 
的 。“ 数 据 传输 率 ” 是 指 在 一 条 信道 中 ， 单 位 时 间 内 传输 的 信息 量 ， 与 
我 们 平时 描述 河流 水 速 是 一 样 的 。 数 据 传输 速率 可 用 比特 率 (针对 数 
字数 据 ) 或 波 特 率 〈 针 对 模拟 数据 ) 来 表示 。 


(1) 比特 率 


比特 率 通 常 又 称 信息 传输 速率 ， 是 指 单位 时 间 内 传输 的 二 进 制 代 
码 的 有 效 位 (bit) 数 ， 用 Rh (注意 这 里 是 小 写 的 b) 表示。 比特 率 是 
用 来 描述 可 直接 在 计算 机 网 络 数字 线路 上 传输 的 数字 数据 的 传输 速 
率 ， 常 用 的 单位 有 bit/s (b/s 或 bps， 每 秒 比 特 数 ) 、kbit/s (kb/s 或 
kbps， 每 秒 千 比特 数 ) 或 Mbit/s (Mb/s 或 Mbps， 每 秒 兆 比 特 数 ) 。 但 


要 注意 ， 此 处 的 k 和 M 分 别 为 1000 和 1 000 000， 而 不 是 涉及 计算 机 存储 
器 容量 时 的 1024 和 1048576 。 


根据 以 上 “比特 率 ” 的 定义 ， 可 用 以 下 公式 来 计算 信息 传输 速率 。 
Rp =1/T (b/s) (4-1) 


其 中 ，R 为 信息 传输 速率 ，T 为 发 送 每 一 比特 数据 所 需要 的 时 
间 。 例 如 ， 如 果 在 通信 信道 上 发 送 1 位 0 或 1 信号 所 需要 的 时 间 是 
0.001ms， 那 么 根据 公式 可 计算 出 信道 的 数据 传输 速率 为 1 000 
000bps=1Mbps 。 


(2) 波 特 率 


波 特 率 (Baud rate) 是 指 一 个 数字 信和 号 在 被 调制 后 ， 数 字 信 和 号 对 
载波 的 调制 速率 ， 也 即 单位 时 间 内 载波 参数 《如 频率 、 相 位 等 ) 变化 
的 次 数 ， 单 位 为 B。 如 有 果 是 非 调制 的 二 进 制 数 字 信 号 ， 波 特 率 与 比特 
率 数 值 上 二 相等 的 ， 所 以 波 特 率 通 和 是 针对 经 过 调制 后 的 数字 信和 号 传 


波 特 率 的 单位 为 Baud， 用 Rp (注意 这 里 是 大 写 的 B) 表示 。 一 个 
数字 脉冲 ， 或 者 直接 说 是 一 个 二 进 制 位 称 为 一 个 码 元 (如 图 4-9 所 
示 ) ， 波 特 率 也 可 以 理解 为 在 单位 时 间 内 传输 的 码 元 数 。 这 里 的 码 元 
可 以 是 二 进 制 的 ， 也 可 以 是 多 进 制 的 。 如 二 进 制 的 字母 A 的 ASCII 码 是 


01000001， 可 用 7 个 脉冲 来 表示 〈 最 高 位 为 校 验 位 ， 不 计 入 人 码 元 中 ) ， 
所 以 A 可 认为 是 由 7 个 码 元 组 成 的 。 若 1s 内 传 2400 个 码 元 ， 则 波 特 率 为 
2400B 。 


(3) 比特 率 与 波 特 率 的 关系 


对 于 数字 数据 ， 比 特 率 与 波 特 率 的 关系 与 数据 所 采用 的 进 制 有 
天 。 因 为 每 个 码 元 或 符号 通 稼 都 含有 一 定 比 特 数 的 信息 量 ， 所 以 比特 
率 (Rb ) 与 波 特 率 (Re ) 有 如 下 关系 : 


Rp =Rp xlog M(b/s) (4-2) 


式 中 的 M 为 符号 的 进 制 数 ， 如 二 进 制 、 八 进 制 、 十 六 进 制 。 例 如 
码 元 速率 为 1200B， 采 用 八进制 (M=8) 时 ， 则 可 计算 出 对 应 的 信息 
速率 Rh =1200xlog, 8=3600(b/s); 如 果 采 用 的 是 二 进 制 (M=2) ， 则 信 
息 速 率 为 Ri =1200xlog 2=1200(b/s)， 可 见 ， 二 进 制 的 波 特 率 和 比特 率 
在 数值 上 是 相等 的 。 


在 采用 了 数字 调制 技术 的 数字 通信 中 ， 比 特 率 与 波 特 率 的 关系 还 
与 所 采用 的 调制 技术 有 关 。 因 为 具体 的 调制 技术 将 在 本 章 后 面 专门 介 
绍 ， 所 以 在 此 仅 给 出 它们 的 关系 式 ， 关 系 式 与 式 (4-2) 一 样 。 不 过 ， 
此 时 M 代 表 的 是 调制 的 相位 数 。 


两 相 调制 (单个 调制 状态 对 应 1 个 二 进 制 位 ) 的 比特 率 的 数值 等 于 
波 特 率 的 数值 ， 四 相 调 制 (单个 调制 状态 对 应 2 个 二 进 制 位 ) 的 比特 率 
的 数值 为 波 特 率 的 数值 的 2 倍 ， 八 相 调制 (单个 调制 状态 对 应 3 个 二 进 
制 位 ) 的 比特 率 的 数值 为 波 特 率 的 数值 的 3 倍 ; 依 此 类 推 。 


(4) 传输 佛 禄 


“市 宽 ? 是 指 信 道中 每 秒 传输 的 最 大 信息 量 ， 也 束 是 一 个 信道 的 最 
大 数据 传输 速率 ， 单 位 也 是 “位 / 秒 ”(b/s 或 bpps) 。 带 宽 旦 一 种 理想 状 
态 (不 受 任何 干扰 ， 没 有 任何 衰减 ) 下 的 信道 传输 速率 ， 而 上 节 介 绍 
的 “数据 传输 速率 ”是 指 当 前 实际 的 数据 传输 速率 ， 通 常情 况 下 “数据 传 
输 速率 ?永远 小 于 或 等 于 “带宽 ” 值 (事实 上 一 般 不 可 能 等 于 带宽 的 ， 因 
为 传输 过 程 中 不 可 能 完全 不 受 干扰 ， 线 路 性 能 一 般 也 不 可 能 完全 达到 
理想 状态 ) 。 可 以 打 这 样 一 个 比方 ， 如 一 条 河流 它 能 承受 的 最 大 水 流 
速度 为 1000m3 /s， 但 现在 由 于 河 里 的 水 不 多 ， 实 际 的 水 流速 度 仅 
100m3 /s。 这 了 束 是 传输 市 宽 与 数据 传输 速率 的 关系 了 。 


4.3.2 ”数字 信和 号 不 失真 传输 的 最 大 传输 速率 限制 


物理 层 的 任何 一 个 信道 ， 它 所 能 承受 的 信号 频率 (或 者 说 是 信道 
带宽 ) 是 有 限 的 ， 殊 像 任 何 一 条 河流 只 能 承受 一 定 峰值 的 水 流量 一 
样 。 在 信道 中 ， 超 出 限定 的 频率 范围 的 信号 都 将 被 直接 滤 出 ， 不 能 通 
过 信道 ， 束 像 河流 中 任何 超出 它 流速 限制 的 水 流量 最 终 不 能 形成 实际 
速率 的 水 流量 一 样 。 


在 数据 通信 中 有 数字 信和 号 传输 和 模拟 信号 传输 之 分 (对 应 也 就 有 
数字 信道 和 模拟 信道 之 分 了 ) ， 但 数字 信号 的 传输 要 求 与 模拟 信和 号 的 
要 求 不 同 : 模拟 信号 的 传输 要求 接收 端 无 波形 失真 ， 而 数字 信和 号 的 传 
输 则 要 求 接 收 端 无 差错 地 恢复 成 原来 的 二 进 数 码 (可 以 允许 接收 波形 
失真 ， 只 要 不 影响 正确 恢复 信号 编码 即 可 ) 。 在 模拟 信号 传输 中 ， 为 
了 达到 不 失真 的 效果 ， 束 需要 对 由 模拟 信号 转换 成 数 子 信 号 过 程 中 的 
采样 频率 进行 限制 ， 而 在 数字 信和 与 传输 中 ， 束 需要 对 信和 与 传输 速率 进 
行 限制 。 本 市 仅 介绍 数字 信号 传输 中 信号 传输 速率 的 限制 。 


在 计算 数字 信道 中 最 大 传输 速率 方面 ， 有 两 个 非常 有 名 的 准则 或 
定理 ， 那 就 是 蒜 奎 斯 特 准则 〈 简 称 奈 氏 准则 ) 和 香农 公式 。 


1. 奈 奎 斯 特 准 则 


由 于 数字 信号 〈 这 里 特 指 没有 被 调制 的 原始 数字 信号 ， 也 就 是 上 
面 所 说 的 数字 基带 信号 ) 的 频带 (这 里 是 指 信号 的 频率 带宽 ) 可 以 非 
常 宽 (从 直流 一 直到 无 限 高 的 频率 ) ， 但 其 主要 能 量 集中 在 低频 段 ， 
而 且 数 据 通信 中 的 电缆 传输 信道 只 允许 比较 低 的 频率 成 分 通过 理想 低 
通信 道 ， 高 频 成 分 将 被 滤 去 ， 这 就 造成 了 输出 波形 的 失真 。 失 真 的 输 
出 波形 顶部 变 圆 ， 底 部 变 宽 〈 称 为 波形 拖 尾 ) ， 使 得 一 个 码 元 的 波形 
展 宽 到 其 他 码 元 位 置 ， 影 响 到 其 他 码 元 ， 这 种 影响 称 为 码 间 干扰 。 


出 现 码 间 干 扰 后 ， 波 形 的 拖 尾 可 以 是 正 ， 也 可 以 是 负 : 如 有 果 某 个 
码 元 内 所 有 的 拖 尾部 分 相 加 后 是 正 值 ， 而 且 达 到 门限 判决 电 平 (也 就 
征 判 断 信号 电 平 为 1 或 为 0 的 基准 电 平 ) 就 可 能 将 “0? 误 判 为 “1? 码 ; 反 
之 ， 如 果 所 有 的 拖 尾 相 加 后 在 某 个 码 元 内 的 值 是 负 的 ， 束 可 能 将 “1? 码 
误 判 为 “0" 码 。 


说 明 理想“ 低 通 信道 "是 指 只 要 信和 与 频率 不 超过 某 个 上 限 值 都 能 
够 不 失真 地 通过 此 信道 ， 而 频率 超过 该 上 限 值 的 所 有 高 频 分 量 都 不 能 
通过 该 信道 。 与 之 相对 的 还 有 一 种 称 为 理想 “市 通 矩 形 信道 ”， 它 是 指 
仅 允 许 在 上 下 限 之 间 的 信号 频率 成 分 不 失真 地 通过 ， 其 他 频率 成 分 不 


能 通过 。 


要 使 信道 中 传输 的 数字 信和 号 不 失真 ， 信 道中 的 数据 传输 速率 必须 
限制 在 某 个 范围 之 内 ， 这 又 与 信道 类 型 有 关 。1924 年 ， 糯 国 若 名 物理 
学 家 蒜 码 斯 特 (Nyquist) ， 经 过 多 次 实验 证 明 ， 为 了 确保 数字 信和 号 不 


失真 传输 ， 在 理想 低 通信 道 《也 就 是 在 4.1.4 世 介绍 的 基带 传输 中 的 信 
道 ) 下 实际 的 最 高 码 元 传输 速率 〈 即 无 码 间 干扰 的 最 高 波 特 率 ) 必须 
在 下 式 计 算 结果 之 内 : 


最 高 码 元 传输 速率 (MaxRB) =2W (4-3) 


式 中 W 征 理想 低 通信 道 的 带宽 ， 单 位 为 攻 (Hz) ，MaxRB 为 最 高 
码 元 传输 速率 ， 单 位 为 Raud ( 波 特 ) 。 这 就 是 著名 的 蒜 奏 斯 特 第 一 准 
则 ， 其 指出 了 在 理想 低 通信 道 《也 就 是 4.2.4 世 中 介绍 的 基带 传输 中 的 
信道 ) 中 ， 为 了 确保 数字 信号 的 不 失真 传输 ， 信 道 带 宽 和 最 大 码 元 传 
输 速率 之 间 的 关系 。 从 该 公式 可 以 得 出 ， 每 赫 效 带宽 的 理想 低 通 信道 
的 最 高 码 元 传输 速率 是 每 秒 2 个 码 元 。 寿 码 元 的 传输 速率 超过 了 这 一 准 
则 所 给 出 的 数值 则 将 出 现 码 间 干 扰 ， 以 致 在 接收 问 无 法 正确 判定 码 元 


是 1 还 是 0。 


说 明 ” 奈 奎 斯 特 是 美国 的 一 位 著名 物理 学 家 。 他 1889 年 出 生 于 瑞 
典 ，1907 年 移民 到 美国 并 于 1912 年 进入 北 达 克 塔 大 学 学 习 ，1917 年 在 
耶鲁 大 学 获得 物理 学 博士 学 位 ，1917 年 ~1934 年 在 AT&T 公 司 工 作 ， 后 
转 入 贝尔 电话 实验 室 工 作 ， 最 终于 1976 年 在 德 克 萨 斯 逝世 。 奈 奎 斯 特 
对 信息 论 做 出 了 重大 的 贡献 。 


例如 ， 低 通信 道 带宽 为 2000Hz 时 ， 最 高 码 元 传输 速率 就 为 4000 
Baud， 即 每 秒 最 多 可 传送 4000 个 二 进 制 码 元 。 反 过 来 ， 根据 最 大 人 码 元 


传输 速率 也 可 算出 信道 带宽 。 如 一 路 数字 电话 速率 为 64kbps (因为 是 
数字 电话 ， 采 用 的 是 二 进 制 ， 所 以 比特 率 的 数值 与 波 特 率 的 数值 是 相 
等 的 ， 所 以 此 电话 的 波 特 率 为 64000 Baud) ， 则 根据 以 上 公式 可 计算 
出 无 码 间 干扰 的 信道 市 宽 为 32kHz 。 


男 外 ， 在 妹 人 斯 特 第 一 准则 中 也 同时 得 出 ， 在 理想 带 通 和 矩形 信道 

(也 就 是 在 4.2.4 节 介绍 的 频带 传输 中 的 信道 ) 下 的 最 高 码 元 传输 速率 

与 信道 带宽 是 具有 相等 值 关 系 的 ， 即 每 赫兹 宽带 的 带 通 信道 的 最 高 码 
元 传输 速率 为 每 秒 1 个 码 元 。 


2. 香 农 公 式 


以 上 和 奈 硅 斯 特 第 一 准则 描述 了 有 限 带宽 、 无 噪声 信道 的 最 大 数据 
传输 速率 与 信道 带宽 的 关系 。 美 国 的 另 一 位 著名 物理 学 家 一 一 克 劳 德 
香农 (Claude Elwood Shannon) 也 在 数据 通信 和 领域 有 权威 的 发 现 ， 那 就 
是 “香农 公式 ”。 这 个 公式 描述 了 有 限 信道 带宽 、 有 随机 热 噪 声 信 道 

(更 接近 真实 环境 ) 的 最 大 传输 速率 与 信道 带宽 、 信 噪 比 (信号 平均 
功率 与 噪声 功率 之 比 ) 之 间 的 关系 。 香 农 公 式 指 出 : 在 有 随机 热 噪声 
的 信道 上 传输 数据 信号 时 ， 最 大 数据 传输 速率 Rmax 与 信道 带宽 B、 信 
喧 比 SN 的 关系 如 下 所 示 : 


Rmax=Bxlog, (1+S/N) (4-4) 


式 中 Rmax 的 单位 为 bps， 信 道 带宽 B 的 单位 为 Hz， 信 噪 比 SN 通常 
用 dB (分 贝 ) 表示 ， 可 用 10xlogj。 (S/N) 公式 来 计算 信 噪 比 的 分 由 
数 。 若 已 知 S/N=1000， 则 根据 公式 可 很 快 得 出 用 分 贝 数 表示 的 信 品 比 
为 30dB。 如 果 再 已 知 信道 带宽 B=3000Hz， 则 Rmaxx30kbps。 它 表示 对 
于 带 视 只 有 3000Hz 的 通信 信道 ， 信 噪 比 在 30dB 时 ， 无 论 数据 采用 二 进 
制 或 更 多 的 离散 电 平 值 表示 ， 都 不 能 用 越过 30kbps 的 数据 传输 速率 。 


4.3.3 ”模拟 信号 不 失真 还 原 的 最 小 采样 频率 限制 


上 市 介绍 了 数字 信和 与 不 失真 传输 时 ， 信 道中 的 最 大 传输 速率 限 
制 ， 本 节 要 介绍 的 是 模拟 信号 传输 中 在 接收 端 不 失真 还 原 的 最 小 采样 
频率 限制 。 


我 们 知道 ， 在 计算 机 设备 中 只 能 接收 数字 信和 号， 如 有 果 在 信道 中 传 
输 的 是 模拟 信号 (通过 公共 交换 电话 网 络 进行 的 远程 网 络 连接 的 电话 
线路 中 传输 的 都 是 模拟 信号 ) ， 在 接收 端 必须 进行 模 / 数 转换 ， 生 成 数 
字 信 号 ;同样 如 果 将 在 一 个 计算 机 设备 中 的 数字 信号 还 原 到 茶 条 模拟 
线路 中 进行 传输 ， 则 又 要 进行 数 / 模 转 换 ， 还 原 成 原来 的 模拟 信和 号。 这 
里 最 关键 的 是 由 模拟 信号 转换 成 数字 信号 ， 因 为 在 这 个 转换 过 程 中 要 
确保 数据 不 失真 。 


因为 模拟 信号 是 随时 间 连 续 变 化 的 ， 而 数字 信号 则 是 离散 的 ， 所 
以 在 模 / 数 转 换 过 程 中 ， 就 需要 离散 地 在 模拟 信号 上 抽取 一 定 的 信号 样 
本 ， 形 成 数字 信和 号 样本 ， 以 便 可 以 不 失真 地 代表 原始 数据 本 号 ， 也 使 
得 抽取 的 数 子 信 号 样本 在 需要 时 能 还 原 为 原始 的 模拟 信号 。 这 就 涉及 
一 个 “采样 频率 ”( 人 简单 地 说 就 是 每 隔 多 少时 间 提 取 一 次 信号 波 ) 的 问 


题 。 


从 信号 处 理 的 角度 来 看 ， 采 样 定理 描述 了 两 个 过 程 : 其 一 是 采 
样 ， 这 一 过 程 将 连续 时 间 信 号 转换 为 离散 时 间 信 和 号， 其 二 是 信和 号 的 重 
建 ， 这 一 过 程 是 将 离散 信号 还 原 成 连续 信号 。 连 续 信 号 在 时 间 《或 空 
间 ) 上 以 某 种 方式 变化 着 ， 而 采样 过 程 则 是 在 时 间 (或 空间 ) 上 ， 以 
TI 为 单位 间隔 来 测量 连续 信号 的 值 。T 称 为 采样 间隔 。 在 实际 中 ， 如 果 
言 号 是 时 间 的 函数 ， 通 党 它们 的 采样 间 阳 都 很 小 ， 一 般 在 毫秒 、 微 秒 
的 量 级 。 采 样 过 程 产生 的 一 系列 的 数字 称 为 样本 ， 代 表 了 原来 的 信 
号 。 每 一 个 样本 都 对 应 着 测量 这 一 样本 的 特定 时 间 点 ， 而 采样 间隔 的 
倒数 ， 即 1/T 表 示 采 样 频率 (fs, ) ， 其 单位 为 样本 / 秒 ， 即 赫 (Hz) 。 
言 号 的 重建 是 对 样本 进行 插值 的 过 程 ， 即 从 离散 的 样本 x[m] 中 ， 用 数 


学 的 方法 确定 连续 信号 x(t)。 


要 确保 信号 不 失真 的 恢复 ， 最 低 的 采样 率 需 要 达到 多 少 呢 ?采样 
过 程 所 应 遵循 的 规律 称 为 采样 定理 ， 又 称 取样 定理 、 抽 样 定 理 。 采 样 
定理 说 明 采 样 频 率 与 信号 频谱 之 间 的 关系 ， 是 连续 信 与 离散 化 的 基本 
依据 。 采 样 定理 于 1928 年 由 美国 物理 学 家 奈 奎 斯 特首 移 提出 来 ， 因 此 
称 为 村 奎 斯 符 采 样 定理 。1933 年 苏联 工程 师 科 捷 利 尼 科 夫 秆 次 用 公式 
产 格 地 表述 这 一 定理 ， 因 此 在 苏联 文献 中 称 为 科 捷 利 尼 科 夫 采 样 定 
理 。1948 年 信息 论 的 创始 人 香农 对 这 一 定理 加 以 明确 说 明 并 正式 作为 
定理 引用 ， 因 此 在 许多 文献 中 又 称 为 香农 采样 定理 。 


上 述 采 样 定理 又 有 许多 表述 形式 ， 但 最 基本 的 表述 方式 是 “时 域 采 
样 定理 * 和 “ 频 域 采样 定理 ”。 在 计算 机 网 络 的 数据 通信 中 ， 主 要 用 到 的 
是 “时 域 采样 定理 ”。 


时 域 采样 定理 中 规定 ， 频 带 为 F 的 连续 信号 f(t) 可 用 一 系列 离散 的 
采样 值 f(t; )，fft +At),，f(ty +2At)，...... 来 表示 ， 只 要 这 些 采样 点 的 时 
间 间 隔 At<1/2F， 便 可 根据 各 采样 值 完 全 恢复 原来 的 信号 fb。 简 单 地 
讲 就 是 ， 在 进行 模拟 /数字 信号 的 转换 过 程 中 ， 当 采样 频率 fax 大 于 
或 等 于 信号 中 最 高 频率 fu 的 2 倍 时 (f。 sx >2fusx )， 采 样 之 后 的 数字 
信号 就 可 完整 地 保留 原始 信号 中 的 信息 ， 原 来 的 连续 信号 就 可 以 从 采 
样 样本 中 完全 重建 出 来 ， 否 则 采样 信号 后 的 频率 将 会 混 芋 。 一 般 实 际 
应 用 中 保证 采样 频率 为 信号 最 高 频率 的 5~10 倍 。 


由 以 上 定理 可 以 得 知 ， 如 果 已 知 信 号 的 最 高 频率 fy ， 就 可 以 得 出 
傈 证 完全 重建 信号 的 最 低 采 样 频率 是 2fy 。 相 反 ， 如 采 已 知 采 样 频 
率 ， 则 可 以 得 出 保证 信号 完全 重建 所 允许 的 最 高 信号 频率 。 但 要 注意 
的 是 ， 这 里 有 一 个 条 件 ， 那 束 是 被 采样 的 信号 必须 是 市 限 的 ， 也 束 古 
和 是 有 限 市 宽 的 ， 信 号 中 高 于 某 一 给 定 频率 的 成 分 必须 是 0， 或 者 至 少 非 
党 接近 0。 只 有 这 样 ， 在 重建 信号 时 这 些 频 率 成 分 的 影响 才 可 以 忽略 不 
计 。 如 有 果 被 采样 的 信号 不 是 市 限 的 ， 采 样 后 信号 的 频率 束 会 产生 重 
登 ， 即 高 于 采样 频率 一 半 的 成 分 将 被 重建 成 低 于 采样 频率 一 半 的 信 


号 ， 最 终 导 致 信号 不 能 被 完全 恢复 。 


频 域 采样 定理 中 规定 了 对 于 时 间 上 受 限制 的 连续 信号 f(t) 的 采样 频 
率 。 因 为 比较 复杂 ， 且 在 数据 通信 中 比较 少 用 ， 故 在 此 不 再 介绍 。 


4.4 数字 基 市 信号 编码 


在 本 章 前 面 我 们 提 到 了 ， 数 字 基 带 传输 模式 中 传输 的 信号 是 要 经 
过 编码 的 原始 数字 信号 。 但 数字 基 融 信号 的 类 型 有 很 多 ， 第 见 的 有 和 撼 
形 脉冲 、 三 角 波 、 高 斯 脉冲 和 余弦 脉冲 等 。 其 中 最 常用 的 古 和 矩形 脉 
冲 ， 因 为 矩形 脉冲 易于 形成 和 变换 。 本 市 先 介绍 矩形 脉冲 数字 信号 中 
几 种 利 见 的 流 形 和 编码 方式 。 


4.4.1 宅 形 脉冲 数字 信和 号 基本 波形 


在 和 矩形 脉冲 数字 信号 中 主要 有 以 下 四 种 波形 : 单 极 性 不 归 零 站 
形 、 单 极 性 归 零 波形 、 双 极 性 不 归 零 波形 、 双 极 性 归 零 波形 。 


1. 单 极 性 波形 与 双 极 性 波形 


在 以 上 四 种 矩形 脉冲 波形 中 首先 要 理解 两 个 概念 ， 那 就 是 什么 
征 “ 单 极 性 "， 什 么 是 “ 双 极 性 ”。 


“ 单 极 性 ”就 是 波形 中 仪 用 正 (或 负 ) 电 平 值 来 表示 信号 中 的 二 进 
制 <1” (通常 是 以 正 电 平 表示 ) ， 零 电 平 表示 信和 号 中 的 二 进 制 “0”。 对 应 
电 平 信号 是 1 还 是 0 〈 也 就 是 通常 所 说 的 “判决 电 平 ?) 以 信号 电 乎 矩形 
脉冲 幅度 ( 即 信号 波 的 “振幅 *) 的 1/2 为 基准 ， 信 号 电 平 值 大 于 或 等 于 


振幅 的 1/2 时 就 用 1 表示 ， 小 于 振幅 的 1/2 时 就 用 0 表示 。 之 所 以 称 之 
为 “ 单 极 性 ”"， 就 古 因 为 它 仅 使 用 了 其 中 一 个 极 性 〈 要 么 用 正 ， 要 人 么 用 
负 ， 一 般 用 正极 性 ) 。 如 图 4-22a 所 示 的 就 是 一 个 信号 代码 为 
0101101010 的 单 极 性 矩形 脉冲 波 。 


而 “ 双 极 性 ”是 指 分 别 用 正和 人 负电 平 值 表 示 信 号 中 的 二 进 
制 <1” 和 “0”， 而 且 正 、 负 脉冲 幅度 一 样 。 此 时 的 判决 电 平 束 是 零 电 平 ， 
言 写 电 平 值 大 于 0 时 用 1 表示 ， 信 号 电 平 值 小 于 0 时 用 0 表示 。 之 所 以 称 
之 为 “ 双 极 性 * 就 是 因为 它 同 时 使 用 了 正 、 负 两 种 极 性 。 


如 图 4-22b 所 示 的 是 一 个 信号 代码 为 0101101010 的 双 极 性 矩形 脉冲 
波 。 


0 
数字 信号 代码 


O ! 时 间 


a ) 单 极 性 矩形 脉冲 波形 


b ) 双 极 性 矩形 脉冲 波形 


图 4-22 单 极 性 矩形 脉冲 波形 和 双 极 性 矩形 脉冲 波形 


以 上 两 种 波形 部 是 在 一 个 码 元 的 全 部 时 间 内 发 出 或 不 发 出 电流 
( 仅 适 用 于 单 极 性 波形 ， 以 及 发 出 正 电 流 或 负电 流 〈 仅 适用 于 双 极 
性 波形 ) 。 每 一 位 编码 占用 整个 码 元 的 视 度 ， 所 以 这 两 种 编码 都 属 
于 “全 宽 码 ”。 但 这 样 的 波形 存在 一 个 码 元 难以 识别 的 问题 ， 因 为 当 连 
续 发 送 1 码 ， 或 者 0 码 时 ， 吏 会 使 某 一 位 码 元 与 其 下 一 位 码 元 之 间 没 有 
间隙 〈 因 为 持续 有 电流 ) ， 容 易 使 接收 方 误 认 为 对 应 的 信号 电 平 是 稳 
定 的 直流 电 平 。 正 因 如 此 ， 在 数据 通信 中 一 般 不 是 直接 采用 这 种 原始 


波形 进行 传输 的 ， 而 是 采用 了 归 零 码 这 种 编码 方式 ， 而 原来 这 种 不 重 
新 编码 的 波形 称 为 非 归 零 码 。 非 归 零 码 在 传输 中 难以 确定 一 位 的 结束 
和 男 一 位 的 开始 ， 需 要 用 某 种 方法 对 发 送 器 和 接收 器 进行 定时 或 同 
步 。 


2. 归 段 码 与 非 归 零 码 


理解 什么 是 归 零 码 和 非 归 零 的 关键 就 是 要 理解 什么 是 归 零 。 归 办 
是 指 信号 电 平 在 一 个 码 元 宽度 内 (通常 是 在 1/2 个 码 元 时 ) 信号 脉冲 电 
平 必须 回归 为 零 电 平 也 就 是 无 电流 ) ， 直 到 该 码 元 宽度 结束 。 非 归 
零 码 就 是 不 对 脉冲 信号 波 进行 任何 编码 ， 原 来 是 什么 样子 ， 传 输 的 就 
是 什么 样子 。 


因为 矩形 脉冲 波 有 单 极 性 和 双 极 性 之 分 ， 归 和 零 码 对 应 有 单 极 性 归 
零 码 和 双 极 性 归 零 码 ， 非 归 零 码 对 应 有 单 极 性 非 归 零 码 和 双 极 性 非 归 
零 码 。 一 般 来 说 ， 直 接 采 用 单 极 性 非 归 零 码 和 双 极 性 非 归 零 码 比较 
少 。 单 极 性 非 归 零 码 主要 适用 于 极 短 距离 传输 ， 更 多 是 需要 再 进行 其 
他 形式 的 编码 ， 如 下 市 将 要 介绍 的 各 种 传输 码 ， 都 是 在 单 极 性 非 归 零 
码 基础 上 改进 的 ， 最 终 都 变 成 了 双 极 性 的 编码 。 双 极 性 非 归 零 码 常 在 
CCITT 的 V 系 列 接口 标准 或 RS-232 接 口 标准 中 使 用 。 


从 以 上 对 归 零 这 两 个 字 的 理解 ， 我 们 可 以 很 快 理解 单 极 性 归 零 码 
的 含义 。 因 为 单 极 性 非 归 零 码 仅 采用 一 个 极 性 ， 并 且 “1? 码 表示 有 信和 号 


(是 正 电 平 还 是 负电 平 ， 取 决 于 所 选择 的 极 性 ) ，“0” 码 表示 无 信号 
( 零 电 平 ) ， 所 以 把 单 极 性 非 归 零 码 转换 成 单 极 性 归 零 码 就 很 简单 

了 ， 只 需要 把 “1” 码 的 脉冲 电 平 在 其 码 元 宽度 内 〈 通 党 是 在 1/2 个 码 元 
时 ) 从 正 电 平 或 负电 平 回 归 到 零 电 平 ， 一 直 持 续 到 该 码 元 结束 ， 原 来 
为 “0” 码 的 保持 零 电 平 不 变 ， 因 为 它 已 是 零 电 平 了 ， 再 回归 零 电 平 还 是 
零 电 平 。 图 4-23 所 示 的 就 是 一 个 单 极 性 非 归 零 码 转换 为 单 极 性 归 零 码 的 
示例 。 


es 数字 信和 号 代码 


0 时 间 


a ) 单 极 性 非 归 零 码 


~ 数字 信号 代码 


© 时 间 


b ) 单 极 性 归 零 码 


图 4-23 单 极 性 非 归 零 码 转换 为 单 极 性 归 零 码 的 示例 


从 以 上 叙述 可 以 看 出 ， 单 极 性 归 零 码 的 主要 优点 是 可 以 直接 提取 
同步 信号 ， 因 为 在 出 现 连续 的 1 码 元 时 ， 都 会 有 一 个 小 段 《通常 为 1/2 个 
码 元 宽度 ) 的 零 电 平 间隙 ， 不 会 出 现任 何 两 个 码 元 连续 的 正 电 平 (或 
人 负电 平 ，， 比 较 容易 区 分 有 信号 时 两 个 码 元 之 间 的 界限 。 但 它 仍 有 一 
个 不 足 ， 就 古 当下 一 个 码 元 也 古 无 信和 号 的 零 电 平时 ， 则 两 个 码 元 仍 会 
征 连 续 的 零 电 乎 ， 仍 比较 难 实现 数据 传输 的 同步 ， 因 为 仍 不 能 区 分 两 
个 连续 0 码 元 的 界限 。 而 且 单 极 性 码 中 采用 了 零 电 平 ， 包 括 了 直流 和 低 
频 成 分 ， 不 利于 在 信道 中 传输 。 


由 双 极 性 非 归 零 码 转换 成 双 极 性 归 零 码 的 原则 的 理解 ， 主 要 也 是 
对 “ 归 零 "两 个 字 的 理解 ， 具 体 的 理解 方式 同上 ， 只 不 过 ， 因 为 双 极 性 
非 归 零 码 中 的 信号 不 是 采用 零 电 平 ， 而 十 采用 正 电 平 来 表示 1 码 元 ， 负 
电 平 表示 0 码 元 ， 所 以 此 时 的 双 极 性 归 零 码 中 的 两 个 极 性 (不 管 是 正 电 
平 ， 还 是 负电 平 ) 的 码 元 电 平 都 必须 在 一 个 码 元 宽度 内 (通常 也 是 在 
1/2 个 码 元 时 ) 回归 零 电 平 ， 一 直 持 续 到 该 码 元 结束 。 图 4-24 所 示 的 就 
征 一 个 双 极 性 非 归 零 码 转 换 为 双 极 性 归 零 码 的 示例 。 


~ 数字 信号 代码 
时 间 


a ) 双 极 性 非 归 零 码 
0 
数字 信号 代码 


时 间 


b ) 双 极 性 归 零 码 


图 4-24 双 极 性 非 归 零 码 转 换 为 双 极 性 归 零 码 的 示例 


从 以 上 叙述 可 以 看 出 ， 在 双 极 性 归 零 码 中 永远 不 会 出 现任 何 两 个 
码 元 电 平 的 连续 ， 不 管 是 正 电 平 ， 还 是 负电 平 ， 在 其 码 元 宽度 间 〈 通 
常 为 /2 个 码 元 宽度 ) 都 会 回归 到 零 电 平 ， 每 个 码 元 之 间 都 有 一 个 小 段 
(通常 为 /2 个 码 元 宽度 ) 零 电 平 的 间隙 ， 非 常 容易 区 分 不 同 码 元 ， 也 
非常 容易 实现 数据 的 同步 传输 。 另 外 ， 尽 管 双 极 性 码 编码 前 不 采用 和 零 
电 平 ， 仅 有 正 、 负 电 乎 ， 但 在 编码 后 仍 含有 较 多 的 零 电 税 直流 成 分 
所 以 也 不 宜 在 信道 中 传输 。 


如 琳 把 图 4-22~ 图 4-24 所 示 内 容 合 并 在 一 起 ， 束 更 容易 通过 对 比 看 
出 它们 之 间 的 区 别 ， 以 及 非 归 零 码 转换 成 归 零 码 的 规则 了 ， 如 岁 4-25 所 
示 (它们 传输 的 信号 代码 相同 。 


单 极 性 非 归 零 码 
时 间 


单 极 性 归 零 码 
O 时 间 


1 0 


双 极 性 非 归 零 码 
时 间 


、 ” 双 极 性 归 零 码 
时 间 


图 4-25 单 / 双 极 性 非 归 零 码 和 单 / 双 极 性 归 零 码 的 比较 


4.4.2 ”数字 基 杆 信号 的 传输 码 型 


在 实际 的 基 珊 传输 系统 中 ， 并 不 是 所 有 编码 类 型 的 电信 号 波形 都 
能 在 信道 中 传输 。 例 如 上 市 介绍 的 含有 直流 分 量 和 较 丰 是 低频 分 量 的 
单 极 性 基 上 种 波形 就 不 适宜 在 低频 传输 符 性差 的 信道 中 传输 ， 因 为 其 功 
率 较 弱 ， 在 传输 过 程 中 有 可 能 造成 信号 疗 重 畸变 。 男 外 ， 当 信息 代码 
中 包含 有 长 串 的 连续 “1” 或 “0* 时 ， 非 归 零 波形 呈现 出 连续 的 固定 电 平 ， 
会 出 现 无 法 获取 同步 的 问题 。 单 极 性 归 零 码 在 传送 连续 “0 信息 代码 时 
也 会 存在 同样 的 问题 。 因 此 ， 信 息 码 在 进行 传输 之 前 ， 必 须 经 过 码 型 
变换 ， 变 换 为 适用 于 信道 传输 的 码 型 ， 这 吏 是 通 音 所 说 的 传输 码 ， 也 
称 线路 码 或 信道 编码 。 


传输 码 型 的 选择 原则 : 一 是 要 能 从 基 融 信号 中 提取 定时 信息 (位 
同步 脉冲 信息 ) ， 所 以 要 求 传输 码 型 应 含有 (或 者 经 变换 后 含有 ) 时 
钟 频率 分 量 (不 能 出 现 0 电 平 ，， 且 编码 转换 后 不 能 出 现 过 多 的 连 
续 “0” 码 或 “1” 码 ， 否 则 提取 的 时 钟 信号 束 会 很 不 稳定 ， 引 起 同步 偏 移 ; 
二 是 要 无 直流 分 量 、 低 频 成 分 少 ， 否 则 影响 信和 号 在 信道 中 的 传输 ， 三 
古 信 号 中 高 频 分 量 要 尽量 少 ， 以 市 省 传输 频带 并 减少 码 间 串扰 。 


常见 的 传输 码 型 有 : 传 号 反 转 交替 码 (AMI 码 ) 、 三 阶 高 密度 双 
极 性 码 (HDB3 码 ) 、 传 号 反 转 码 (CMI 码 ) 、 数 字 双 相 码 (曼彻斯特 


码 ) 和 差分 受 彻 斯 特 码 。 上 蔬 介 绍 的 两 种 归 零 码 也 是 传输 码 类 型 。 下 
和 


1.AMI 码 


AMI (Alternative Mark Inversion) 人 码 是 对 单 极 性 非 归 零 码 的 变形 

(也 称 非 归 零 AMI 码 ) ， 其 编码 规则 是 将 单 极 性 非 归 零 码 的 二 进 制 信 
号 代码 中 的 “1” 码 元 交替 地 替换 为 正 、 负 电 平 (可 以 用 +1、-1 来 理 
解 ) ， 而 “0” 码 元 保持 不 变 。 这 里 的 “ 传 号 反 转 交 蔡 ”就 是 指 信和 号 中 “1” 码 
转换 后 变 成 正 、 负 极 性 交替 (但 相 邻 <1” 码 的 极 性 变换 方向 相反 ) 的 代 
码 。 如 一 个 单 极 性 非 归 零 码 中 的 二 进 制 信号 代码 为 10111000101 
1， 转 换 成 AMI 码 后 就 为 TH10-1+1-1000+10-1+1， 对 的 波形 如 图 4- 
26 所 示 。 可 以 看 得 出 ， 其 编码 规则 也 很 简单 。 


b ) AMI 码 


图 4-26 AMI 码 与 单 极 性 非 归 零 码 的 比较 


AMI 码 的 优点 是 : 由 于 “1” 码 元 采用 了 正 、 负 电 平 交 蔡 ， 所 以 AMI 
码 的 有 信号 部 分 的 频谱 中 不 含 直 流 成 分 ， 高 频 和 低频 成 分 也 很 少 。 男 
外 ，AMI 码 的 编译 码 电路 简单 ， 便 于 利用 传 号 极 性 交替 规律 观察 误 码 
情况 。 鉴 于 这 些 优 点 ，AMI 码 是 CCITT 建 议 采 用 的 传输 码 型 之 一 。 


AMI 码 的 不 足 是 ， 当 原 二 进 制 信号 代码 出 现 连续 的 “0” 码 时 ， 信 号 
电 平 会 长 时 间 不 变 ， 造 成 提取 定时 信号 的 困难 (也 就 是 同步 比较 困 
难 ) ， 解 决 连续 “0” 码 问题 的 有 效 方法 之 一 是 采用 后 面 要 介绍 的 HDB3 
码 ， 它 是 AMI[ 码 的 改进 码 型 。 


2.HDB3 码 


为 了 利用 AMI 码 的 优点 ， 并 克服 其 缺点 ， 科 学 家 残 提 出 了 许多 种 
类 的 改进 AMI 码 。 其 中 的 典型 代表 就 是 各 种 高 密度 双 极 性 码 HDBn (所 
以 HDBn 码 也 是 对 单 板 性 非 归 零 码 的 变形 码 ) ，HDB3 码 (High Density 
Bipolar of order 3code) 就 是 高 密度 双 极 性 码 集 中 最 典型 的 一 种 ， 其 最 
关键 的 特性 就 是 可 以 确保 信号 波形 中 连续 零 电 平 (其 实 也 就 是 码 元 连 
续 为 0 的 个 数 ) 的 码 元 数 不 超 过 3 个 。 具 体 的 编码 步 又 如 下 : 


1) 先 把 基带 数字 信和 号 代码 变换 成 AMI 码 ， 然 后 检查 AMI 码 中 的 连 
续 “0” 码 元 的 情况 ， 如 果 信 号 码 中 的 连续 “0” 码 的 个 数 不 超 过 3， 则 这 时 
的 HDB 3 码 就 是 原来 的 AMI 码 。 如 一 个 二 进 制 信号 代码 为 10011011 
0， 转 换 成 的 AMI 码 为 +100 -1+10-1+10， 从 中 可 以 看 出 连续 “0” 码 最 
多 只 有 2 个 ， 没 有 超过 3 个 ， 所 以 该 信号 的 最 终 HDB3 码 与 其 AMI 码 一 
样 。 


2) 当 信 号 AMI 码 中 出 现 连续 4 个 或 4 个 以 上 “0” 码 元 时 ， 则 将 每 4 个 
(就 是 每 4 个 一 组 ， 连 续 “0” 码 元 的 第 4 个 “0” 转 换 成 非 0 脉冲 ， 记 为 +V 
或 -V (是 取 “ 破 坏 ” 之 意 的 Violation 单 词 的 第 一 个 字母 )， 称 之 为 “破坏 
脉冲 *。 原 来 的 信号 码 元 序列 中 所 有 的 “]* 码 称 为 “ 信 码 *"， 用 符号 B 表 
示 。 至 于 第 4 个 “0” 码 是 转换 成 +V 码 ， 还 是 -V 码 ， 取 决 于 以 下 两 个 原 
则 : QV 码 必 须 与 前 一 个 信 码 B 极 性 相同 (同时 为 正 ， 或 同时 为 负 ); 

@ 相 邻 V 码 (包括 +V 码 和 -V 码 ) 的 极 性 必须 相反 。 


图 4-27 所 示 的 是 10000100001 信 号 代码 的 单 极 性 非 归 零 码 、 
AMI 码 和 HDB3 码 的 比较 。 在 第 一 个 连续 4 个 0 码 段 中 ， 把 第 4 个 0 码 的 脉 
冲 变 为 V 脉 冲 ， 因 为 它 前 一 个 信 码 B (也 是 前 一 个 “1” 码 ) 的 极 性 为 正 ， 
所 以 它 的 极 性 也 为 正 。 在 第 二 个 连续 4 个 0 码 段 中 ， 把 第 4 个 0 码 的 脉冲 
也 变 为 V 脉 冲 ， 但 因为 它 前 一 个 信 码 B 的 极 性 为 负 ， 所 以 它 的 极 性 也 为 
人 负 。 最 终 得 到 的 HDB3 码 就 为 +1000+V-1000-V0O+1。 


单 极 性 韭 归 零 码 十 
单 极 性 砷 本 时 间 


信号 电 平 


AMI 码 O 时 间 


信号 电 平和 
HDB3 码 ， | 
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图 4-27 单 极 性 非 归 零 码 、AMI 码 和 HDB3 码 的 比较 示例 


3) 如 果 通 过 变换 V 码 后 ， 得 到 的 波形 还 不 能 同时 满足 以 上 两 个 原 
则 ， 则 需要 将 对 应 的 4 个 连续 “0” 码 的 第 一 个 “0” 码 转换 成 与 该 段 4 个 连 
续 “0” 码 的 V 码 同 极 性 的 补 信 码 ， 用 符号 B' 表 示 。 最 终 使 得 V 码 与 前 一 个 
信 码 (包括 B 码 和 B' 码 ) 的 极 性 相同 ， 相 邻 V 码 的 极 性 以 及 相 邻 信 码 的 
极 性 都 是 相反 的 。 


如 现在 信号 代码 为 100001100001， 如 果 仅 把 第 4 个 “0” 码 转换 
成 对 应 级 性 的 V 码 ， 则 得 到 如 图 4-28 所 示 第 3 个 波形 的 不 正确 HDB3 码 。 
因为 此 时 第 二 个 V 码 的 极 性 为 负 ， 与 它 前 面 一 个 B 码 极 性 不 相同 ， 不 满 
足 第 2 步 中 说 到 的 第 个 原则 。 此 时 就 要 将 第 二 个 连续 4 个 0 码 的 码 段 第 
一 个 “0” 转 换 为 与 前 一 个 B 码 极 性 相反 的 B' 码 。 如 图 4-28 所 示 的 第 4 个 波 
形 即 为 正确 HDB3 码 。 这 时 就 全 部 符合 以 上 规则 了 。 最 终 的 HDB3 码 就 
为 : +1000+V-1+1-B'00-V-1。 
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图 4-28 加 B' 码 的 示例 


HDB3 码 除 保 持 了 前 面 介 绍 的 AMI 码 的 优点 外 ， 同 时 还 将 连 
续 “0” 码 限制 在 3 个 以 内 ， 更 有 利于 位 定时 信号 的 提取 。HDB3 码 是 应 用 
最 为 广泛 的 码 型 ， 已 成 为 CCITT 协 会 推荐 使 用 的 基带 传输 码 型 之 一 。 


3.CMI 码 


CMI (Coded Mark Inversion) 是 一 种 双 极 性 二 电 平 非 归 零 码 ， 又 
称 1B2B 码 ( 即 一 位 信息 码 用 二 位 表示 ) 。 所 谓 “ 二 电 平 ”就 是 一 个 码 用 
两 个 电 平 来 表示 。 通 过 上 这 双 极 性 码 的 介绍 我 们 知道 ,，“1” 码 用 正 电 平 
表示 ,“0” 码 用 人 负电 平 表 示 ， 电 平 判 决 值 就 是 零 电 平 ， 也 惑 古 大 于 零 电 
平 的 码 为 "1”， 小 于 堆 电 平 的 码 为 “0”。 


CMI 码 的 编码 规则 也 比较 人 简单， 就 是 把 基带 数字 信和 号 中 的 “1” 码 交 
替 用 正 、 负 电 平 表示 (也 就 是 如 果 前 一 个 “1” 码 为 正 电 平 的 话 ， 后 一 
个 “1” 码 则 用 负电 平 表示 ) ， 得 到 的 CMI 码 对 应 为 “11”" 和 “00” (两 者 交 
替 出 现 ， 两 个 电 乎 各 占 半 个 码 元 宽度 ) ; “0” 码 固定 用 1/2 码 元 宽度 的 负 
电 平和 1/2 码 元 宽度 的 正 电 平 表 示 (注意 前 后 /2 码 的 极 性 是 固定 的 ) ， 
得 到 的 CMI 码 恒定 为 “01”。 简 单 地 说 就 是 ， 当 传送 一 个 “0” 码 时 ， 编 码 
后 输出 固定 的 “01” 码 ， 当 传送 一 个 “1” 码 时 ， 编 码 后 交替 输出 “11” 或 
者 “00” 码 。 


图 4-29 所 示 的 是 基带 数字 信号 110001110 的 单 极 性 非 归 零 码 和 CMI 
码 的 比较 。 最 终 得 到 的 CMI 码 为 110001010111001101。 从 图 中 可 以 看 
出 ， 原 来 信号 中 的 每 一 位 都 变 成 了 两 位 。 
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图 。 4-29 ”CMI 码 转换 示例 


CMI 码 具有 一 定 的 检测 错误 的 能 力 ， 因 为 “1” 码 交 蔡 地 
用 “11” 和 “00” 来 表示 ， 而 “0” 又 固定 用 “01” 表 示 ， 所 以 正 第 情况 下 ， 转 
换 后 的 编码 “10” 是 不 可 能 在 信道 中 出 现 的 ， 连 续 的 “00” 或 “11” 也 是 不 可 
能 出 现 的 ， 这 样 一 来 束 可 以 用 来 检测 因 信 道 传 输 而 产生 的 错误 。 但 是 
CMI 码 不 能 纠 错 。CMI 码 也 没有 直流 分 量 (没有 零 电 平 ， 只 有 正 、 页 电 
平 ，， 且 有 频繁 出 现 的 波形 跳 变 ， 便 于 恢复 定时 信号 (也 就 是 便于 同 
2 


4. 曼 彻 斯 特 码 


曼彻斯特 码 (Manchester Encoding) 与 上 面 介绍 的 CMI 码 类 似 ， 它 
也 是 一 种 双 极 性 二 电 平 非 归 零 码 。 其 编码 规则 是 ， 每 个 原始 信和 号 码 元 
回 定 用 两 个 连续 极 性 相反 的 脉冲 来 表示 ,，“1”* 码 用 正 、 人 负电 平 表示 (也 
就 是 先 正 后 负 ， 对 应 的 编码 为 “40”) ,，“0” 码 用 负 、 正 电 平 表 示 〈 也 就 


是 先 负 后 正 ， 对 应 的 编码 为 <01”) 。 其 关键 特点 就 是 在 每 一 码 元 的 1/2 
码 元 位 置 必须 进行 极 性 跳 变 。 


图 4-30 所 示 的 是 基带 数字 信号 110001110 的 单 极 性 韭 归 零 码 和 曼 彻 
斯 特 码 的 比较 。 最 终 得 到 的 曼彻斯特 码 为 101001010110101001。 从 图 
中 可 以 看 出 ， 原 来 信号 中 的 每 一 位 都 变 成 了 两 位 。 
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图 4-30 受 彻 斯 特 码 转换 示例 


曼彻斯特 码 的 优点 也 是 无 直流 分 量 (全 部 转换 为 双 极 性 电 平 ， 无 
零 电 平 ) ， 最 长 连续 “0” 码 或 连续 1”* 码 的 个 数 仅 为 2， 非 常 容易 实现 同 
步 ， 编 译 码 电路 和 价 单 。 因 为 如 朱 原 来 基 珊 信号 是 连续 的 “1" 码 ， 转 换 后 
都 为 “10" 两 个 码 了 ， 不 会 出 现 连续 的 “1? 码 ， 如 采 原 来 基 市 信号 是 连续 
的 “0” 码 ， 转 换 后 部 为 “01” 两 个 码 了 ， 不 会 出 现 连 续 的 “1” 码 或 “0” 码 。 
仅 当 原来 基带 信号 是 连续 的 “01” 码 时 ， 才 可 能 出 现 转 换 后 的 连 
续 “0” 码 ; 仅 当 原来 基带 信号 是 连续 的 *10” 码 时 ， 才 可 能 出 现 转换 后 的 

卖 “1” 码 ， 而 且 最 多 仪 2 个 连续 的 “0” 码 或 “1” 码 。 


当 极 性 反 转 时 曼彻斯特 码 会 引起 译 码 错误 ， 为 解决 此 问题 ， 又 引 
入 了 它 的 衍生 码 型 一 一 差分 曼彻斯特 码 (Differential Manchester 
Encoding) 。 差 分 曼彻斯特 编码 是 曼彻斯特 编码 的 一 种 修改 形式 ， 也 是 
每 一 码 元 的 1/2 码 元 位 置 必须 进行 极 性 跳 变 ， 其 不 同 之 处 在 于 不 同位 置 
的 码 元 转换 方式 有 些 不 一 样 。 


对 于 二 进 制 信号 中 的 第 一 个 码 元 ， 与 曼彻斯特 码 的 转换 方式 一 
样 ， 都 是 在 1/2 码 元 时 进行 电 平 极 性 跳 变 ， 即 把 0 码 转换 成 01， 把 1 码 转 
换 成 10。 


后 面 的 信和 号 码 束 根据 下 面 的 规则 进行 跳 变 : 


口 如 果 本 码 为 1， 开 始 处 的 电 乎 不 跳 变 。 也 就 是 说 如 果 上 一 个 码 元 
的 后 1/2 个 半 码 元 是 正 电 平 ， 则 从 本 码 元 开始 处 继续 维持 正 电 平 ， 一 直 
到 1/2 个 码 元 时 才 跳 变 到 人 负电 平 ， 即 “1” 码 变 为 <10” 码 ;如果 上 一 个 码 元 
的 后 1/2 个 半 码 元 是 负电 平 ， 则 从 本 码 元 开始 处 继续 维持 负电 平 ， 一 直 
到 1/2 个 码 元 时 才 跳 变 到 正 电 平 ， 即 “1”* 码 变 为 “01” 码 。 


口 如 果 本 码 为 0， 开 始 处 的 电 平 必须 跳 变 。 也 就 是 如 果 上 一 个 码 元 
的 后 1/2 个 半 码 元 是 正 电 平 ， 则 从 本 码 元 开始 处 跳 变 为 负电 平 ， 一 直到 
112 个 码 元 时 才 跳 变 到 正 电 平 ， 即 “0” 码 变 为 “01” 码 ， 如 果 上 一 个 码 元 的 


后 1/2 个 半 码 元 是 负电 平 ， 则 从 本 码 元 开始 处 跳 变 为 正 电 平 ， 一 直到 1/2 
个 码 元 时 才 跳 变 到 负电 平 ， 即 “0” 码 变 为 “10” 码 。 


从 以 上 转换 规则 可 以 看 出 ， 除 开始 的 一 个 信号 码 外 ， 其 他 的 信号 
码 最 终 如 何 转换 是 不 国定 的 ， 要 根据 对 应 码 是 “0”， 还 是 “1”， 以 及 它 的 
前 一 个 码 转换 后 的 后 1/2 电 平 极 性 而 定 。 如 原来 基带 数字 信和 号 代码 为 
110001110， 首 先 把 开始 信和 号码“1” 转 换 为 “40”"， 后 面 的 码 根 据 以 上 规则 
进行 转换 ， 最 终结 果 如 图 4-31 所 示 ， 从 图 中 可 以 看 出 它 与 曼彻斯特 码 的 
区 别 。 转 换 后 的 差分 曼彻斯特 码 就 为 100101010110011010。 


在 差分 曼彻斯特 编码 中 ， 每 一 码 元 中 间 的 跳 变 也 只 用 来 作为 同步 
的 时 钟 信 号 ， 所 以 它 也 是 一 种 目 同 步 编码 。 但 它 的 时 钟 和 数据 是 分 离 
的 ， 便 于 数据 提取 。 老 分 曼彻斯特 编 码 主要 用 于 令 牌 环 网 。 
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4.5 信号 调制 与 解 调 


在 计算 机 网 络 中 ， 大 多 数 要 传输 的 信号 都 是 具有 较 低 频 市 的 信 
号 ， 这 种 信号 称 为 基 市 信号 。 如 采用 基 市 信号 直接 传输 ， 则 这 种 传输 
方式 称 为 基 市 传输 ， 这 在 本 章 前 面 已 有 介绍 。 但 是 ， 大 多 数 信道 不 适 
宜 进行 基 市 信号 的 传输 ， 因 为 这 样 的 低频 信和 号 在 传输 中 会 产生 很 大 的 
衰减 和 失真 。 在 数字 基 市 传输 中 ， 我 们 知道 可 以 通过 数字 编码 后 在 信 
道中 直接 传输 数字 信号 ， 但 这 也 仅 适 用 于 近 距 离 传输 (如 在 同一 局 域 
网 中 ) ， 在 复杂 网 络 环境 中 〈 如 存在 不 同 传输 介质 和 信道 类 型 的 网 络 
中 ) ， 同 样 不 能 直接 这 样 传输 。 因 此 ， 需 要 将 基带 信号 进行 调制 ， 变 
换 为 适合 信道 传输 的 形式 ， 调 制定 让 基带 信号 去 控制 载波 的 某 个 或 
某 些 ) 参数 ， 使 该 参数 按照 信息 的 规律 进行 变化 ， 这 就 是 “调制 ?过 
程 。“ 解 调和 是 “调制 ”的 地 过 程 ， 即 从 调制 后 的 信号 中 恢复 原来 的 调制 
信号 的 过 程 。 


4.5.1 ”调制 与 解 调 的 关键 术语 


在 调制 和 解 调 过 程 中 涉及 几 个 非常 关键 的 术语 ， 下 面 移 来 介绍 这 
儿 个 术语 。 


1. 调 制 


首先 我 们 要 明日 什么 叫 调制 ， 为 什么 要 进行 调制 。 调 制 最 通俗 的 
解释 就 是 用 一 种 “能 量 大 ”的 信号 承载 (可 简单 地 理解 为 “ 背 上 ”) 另 一 
种 "能量 小 "的 信号 进行 传播 、 传 输 。 承 载 另 一 种 信号 的 信号 我 们 称 为 
载 站 或 者 载波 信号 ， 而 被 承载 信号 才 是 我 们 真正 要 传播 或 者 传输 的 信 
号 。 束 像 不 会 游泳 的 人 坐 在 船上 ， 由 船 渡 我 们 过 河 一 样 ， 此 时 我 们 人 
忠 可 以 比 做 被 承载 信和 号， 而 船 束 可 以 比 做 载波 信 和 号。 


但 是 ， 调 制 不 是 仅 把 被 承载 信号 附加 在 载波 信号 上 整 万 事 大 吉 
了 ， 因 为 在 传输 系统 中 真正 发 挥 作用 ， 需 要 的 还 是 被 承载 信号 ， 载 波 
信号 只 是 一 个 载体 ， 总 得 让 真正 有 用 的 被 承载 信号 发 挥 作用 。 这 时 丈 
得 通过 被 承载 信号 的 有 关 特 性 来 决定 载波 信号 的 幅度 、 频 率 或 者 相 
位 。 束 像 我 们 坐 在 船上 不 是 由 船 目 由 床 流 ， 而 是 由 我 们 人 来 决定 船 的 
行驶 方向 、 路 径 和 速度 等 一 样 。 当 信号 到 了 接收 问 时 ， 我 们 又 得 把 被 
承载 信号 释放 出 来 《相当 于 我 们 人 下 船 } ， 恢 复 它 的 “自由 喘 ”， 只 
这 样 ， 接 收 端 才能 真正 接收 到 有 用 的 信号 。 这 个 释放 的 过 程 下 是 与 调 
制 相 对 的 “ 解 调 ”。 


在 对 数字 信号 进行 载波 调制 时 ， 我 们 所 采用 的 也 是 模拟 载波 调制 
中 的 调幅 、 调 频 和 调 相 这 三 种 调制 技术 。 但 它们 对 应 已 有 了 另外 的 名 
字 : ASK (Amplitude Shift Keying， 幅 度 键 控 ) 、FSK (Frequency 
Shift Keying， 频 率 刍 控 ) 和 PSK (Phase Shift Keying， 相 位 键 控 ) 。 
这 里 之 所 以 都 称 之 为 “ 键 控 >， 是 指 在 这 些 调制 技术 中 都 是 用 电 键 进行 


控制 的 ， 这 是 借用 了 电报 传输 中 的 术语 。 它 们 分 别 对 应 于 利用 载波 
(正弦 波 ) 的 幅度 、 频 率 或 相位 来 承载 数字 基带 信号 ， 可 以 看 做 是 模 
拟 线性 调制 和 角度 调制 的 特殊 情况 。 


2. 调 制 信和 号 


调制 信号 融 是 用 于 对 载波 信号 中 某 个 参数 进行 特性 控制 ， 使 其 按 
照 自己 的 对 应 参数 特性 变化 的 信号 〈 也 是 最 终 要 传输 的 有 用 信号) ， 
以 便 在 接收 端 可 以 根据 这 个 被 控制 的 特性 还 原 出 原始 的 调制 信号 


调制 信号 通常 是 低频 信和 号， 可 以 是 模拟 信和 号， 也 可 以 是 数字 信 
号 ， 所 以 也 就 有 对 应 的 模拟 信号 调制 (或 模拟 调制 ， 和 数字 信号 调制 
(或 数字 调制 ) 。 数 字 调 制 与 模拟 调制 在 本 质 上 没有 什么 区 别 ， 都 属 
于 正弦 波 调 制 ， 只 十 源 信号 不 同 。 数 字 调 制 中 的 产 信 号 为 离散 型 的 脉 
冲 数 字 信 和 号， 而 模拟 调制 中 的 源 信和 号 为 连续 型 的 正弦 波 信 号 。 在 此 仅 
介绍 数字 信和 号 调制 技术 。 


(1) 载波 信和 号 


载波 融 是 用 来 载 送 有 用 低频 调制 信号 的 信号 疲 ， 通 钊 是 一 种 高 频 


信号 。 通 过 调制 技术 束 可 以 把 调制 信号 和 载波 信号 进行 县 加 ， 使 载波 
信号 的 某 些 参数 特性 《如 信号 幅度 、 信 和 号 频率 或 信号 相位 等 ) 按 调制 
信和 号 变化 。 具 体 是 载波 的 哪个 参数 会 随 着 调制 信号 发 生变 化 ， 要 视 具 


体 的 调制 类 型 而 定 ， 如 采 被 控制 的 参数 为 幅度 ， 则 把 这 种 调制 称 为 调 


幅 ， 如 果 被 控制 的 参数 为 频率 ， 则 把 这 种 调制 称 为 调频 ， 如 采 被 控制 
的 参数 为 相位 ， 则 把 这 种 调制 称 为 调 相 。 到 达 接 收 端 后 ， 通 过 解 调 技 
术 从 已 调 信号 中 分 离 出 有 用 的 数据 即 可 。 


那 为 什么 要 用 载波 进行 调制 ? 因为 通 贡 我 们 要 发 送 的 数字 信和 号 的 
频率 是 比较 低 的 ， 如 果 按 照 本 吴 的 频率 来 传输 ， 信 和 号 的 袁 减 比较 疡 
重 ， 不 利于 远 距 离 传输 。 打 个 比方 ， 如 果 我 们 要 送 一 样 物品 (相当 于 
这 里 所 说 的 “调制 信号 ”) 到 达 某 个 比较 远 的 地 方 ， 仅 靠 我 们 人 力 可 能 
很 困难 ， 甚 至 根本 无 法 达到 目的 (因为 我 们 的 速度 很 低 ， 体 力 有 
限 ) ， 但 是 如 果 我 们 使 用 像 汽 车 、 火 车 等 这 类 交通 工具 来 运输 ， 就 很 
轻松 了 ， 这 时 的 交通 工具 束 相 当 于 我 们 这 里 所 说 的 “载波 ”。 使 用 载 汶 
传输 ， 我 们 可 以 将 数据 的 信号 加 载 到 载波 的 信号 上 ， 接 收 方 按照 载波 
的 频率 来 接收 数据 信号 。 由 于 有 用 的 数据 源 信 和 号 波 的 波幅 与 无 用 的 载 
流 信 号 波 的 波幅 是 不 同 的 ， 通 过 进行 波幅 过 滤 束 可 以 将 数据 源 信号 提 
取出 。 


(2) 已 调 信号 


已 调 信号 是 载波 信号 在 被 调 制 信号 调制 后 所 产生 的 新 信号 ， 它 同 
时 具备 了 原来 调制 信号 和 载波 信和 号 的 双重 特性 〈 既 不 完全 等 同 于 原来 
的 调制 信号 ， 也 不 完全 等 同 于 载波 信号 ) 。 如 在 模拟 信号 调制 中 采用 
的 是 调幅 这 种 调制 技术 ， 载 波 的 振幅 会 受 调制 信号 的 控制 ， 但 频率 、 


相位 仍 是 由 载波 信号 决定 的 ， 所 以 最 终 的 已 调 信号 就 古 与 调制 信号 振 
幅 一 致 ， 频 率 和 相位 与 载波 信号 一 致 的 新 信号 。 


(3) 解 调 


解 调 是 调制 的 反 过 程 ， 是 从 已 调 信 号 中 通过 某 种 技术 (如 低 通 滤 
波 器 等 ) 恢复 出 原来 调制 信号 的 过 程 ， 因 为 我 们 最 终 有 用 的 还 是 原来 
的 调制 信号 。 之 所 以 有 要 先 经 过 调制 过 程 ， 束 是 为 了 便于 低频 信号 在 信 
道中 的 远 距 离 、 高 效 传输 。 到 了 目的 地 《接收 端 ) 后 ， 上 自然 要 把 它 还 
原 出 来 。 


4.5.2 ”ASK 调制 与 解 调 


ASK (幅度 键 控 ) 是 一 种 数字 幅度 调制 技术 ， 是 指正 弦 载 波 的 幅 
度 随 数字 基带 信号 变化 而 变化 的 数字 调制 ， 又 称 通 断 键 控 《on- 
offkeying，OOK) 或 者 开关 键 控 。 当 数字 基带 信号 为 二 进 制 码 时 ， 称 
为 二 进 制 振幅 键 控 (2ASK) ， 但 它 仅 适 用 于 单 极 性 数字 信号 。 它 是 利 
用 代表 数字 信息 “0” 或 “1” 的 基 市 矩形 脉冲 去 键 控 一 个 连续 的 载波 ， 使 载 
流 时 断 时 续 地 输出 。 即 源 数字 基 市 信号 为 “1" 时 ， 发 送 载 波 信 号 ， 源 数 
字 基 市 信号 为 “0? 时 ， 发 送 零 电 平 ， 也 吏 是 不 发 送 载波 信号 。 


1.2ASK 调 制 原理 


2ASK 调 制 就 是 以 不 同 的 波幅 来 表示 源 信 号 中 的 不 同 二 进位 值 ， 相 
当 于 用 一 个 如 图 4-32 所 示 的 开关 电路 来 控制 载波 信号 的 输出 。 这 个 开关 
就 是 二 进 制 基带 调制 信号 中 的 “<0” 和 “1”， 当 调制 信和 号 为 “41”* 码 时 ， 相 当 
于 开关 搂 通电 路 ， 有 载波 输出 ; 当 调制 信号 为 “0" 时 ， 相 当 于 开关 上 断 开 
电路 ， 无 载波 输出 。 上 述 是 2ASK 的 键 控 法 ， 另 外 还 有 一 种 模拟 法 ， 采 
用 图 4-33 所 示 的 乘法 器 把 数字 基 市 信号 与 正 驴 载波 进行 乘法 运算 得 出 。 
cosoc {t 为 正 继 载波 信号 ，s(0 为 二 进 制 单 极 性 不 归 零 码 。 
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图 4-32 2ASK 键 控 法 调制 模型 
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图 4-33 2ASK 模 拟 法 调制 模型 


图 4-34 所 示 的 就 是 一 个 2ASK 调 制 示 例 ， 示 例 中 二 进 制 基带 调制 信 
号 为 1011001， 载 波 为 一 正弦 波 。 根 据 以 上 2ASK 的 调制 原理 ， 很 快 就 
可 以 得 到 最 终 的 已 调制 信号 波形 。 
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图 4-34 2ASK 调 制 示 例 


i 


2ASK 信 号 是 数字 调制 方式 中 最 早出 现 的 ， 也 是 最 简单 的 ， 但 其 抗 

能 较 差 〈 因 为 它 仅 是 根据 调制 信号 来 控制 输出 信号 的 幅度 ， 并 

不 能 过 滤 干 扰 信 号 ; ， 因 此 实际 应 用 并 不 广泛 ， 但 经 间作 为 研究 其 他 
数字 调制 方式 的 基础 。 


2.2ASK 解 调 


与 2ASK 调 制 有 键 控 法 和 模拟 法 两 种 方式 类 似 ，2ASK 信 和 号 解 调 也 
有 两 种 方式 非 相 干 解 调 〈 包 络 检 波 法 ) 和 相干 解 调 (同步 检测 
法 ) 。 相 干 解 调 是 指 要 利用 乘法 器 ， 输 入 一 路 与 载波 相干 〈 同 频 同 
相 ) 的 参考 信号 ， 然 后 再 与 载波 相 乘 ， 节 终 得 到 解 调 信 号 ， 这 种 方法 
常用 于 线性 调制 信号 ， 如 ASK 和 PSK; 所 谓 非 相干 解 调 即 不 需 提 取 载 波 


信息 (或 不 需 恢复 出 相干 载波 ) 的 一 种 解 调 方法 ， 这 种 方法 主要 用 于 
FSK， 也 可 用 于 ASK。 


(1) 非 相 干 解 调 


2ASK 的 非 相 干 解 调 模型 如 图 4-35 所 示 ， 与 模拟 信号 解 调 模型 的 不 
同 点 仅 在 于 多 了 一 个 采样 判决 器 ， 因 为 这 是 将 已 调制 的 连续 信号 ( 参 
见 图 4-34) 还 原 为 原始 的 离散 二 进 制 数字 信和 号， 所 以 需要 对 原来 已 调制 
信和 号 进行 采样 。 网 4-34 中 的 Yi (0 表示 的 是 已 调 信 号 。 疼 4-34 中 为 各 步 所 
生成 的 信号 进行 了 标注 ， 以 便于 波形 说 明 。 
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图 4-35 2ASK 非 相干 解 调 模 型 


图 4-36 所 示 的 是 将 一 个 二 进 制 单 极 性 调制 信号 ( 源 信和 号) 
110010001010 调 制 后 并 解 调 还 原 出 调制 信号 的 过 程 。 具 体 步 又 如 下 
(同时 参照 图 4-35) : 


1) 已 调 信 号 yi (0 经 过 融通 滤波 器 (主要 用 于 过 滤 挥 已 调 信号 的 低 
频 和 高 频 干扰 信号 ) 后 得 到 图 4-36 中 的 a 波 ; 


2) a 波 再 经 过 包 络 检 波 器 进行 包 络 检测 (“ 包 络 ”就 是 外 部 表现 的 意 
思 ， 这 里 的 “ 包 络 检测 ?” 融 是 检测 出 信和 号 的 幅度 变化 的 曲线 ， 不 管 频 率 
和 相位 特性 ) 后 得 到 了 b 波 。 对 比 b 和 a 波 可 以 看 出 ， 它 是 一 个 极 性 过 


滤 ， 因 为 调制 信号 是 单 极 性 的 ， 所 以 这 里 仅 允 许 正极 性 的 波形 输出 ; 


3) b 波 再 经 过 低 通 滤波 器 后 就 得 到 了 c 波 。 这 里 的 低 通 滤波 器 用 于 
过 滤 pb 波 中 高 频 成 分 ， 仅 允许 符合 源 信号 频率 特性 的 波形 输出 ; 


4) 最 后 经 过 采样 判决 器 ， 对 连续 型 的 c 波 进行 采样 ， 还 原 出 原始 
的 离散 型 调制 信号 d。 


图 4-36 2ASK 非 相干 解 调 示例 


从 以 上 解 调 过 程 可 以 看 出 ，2ASK 非 相干 解 调 没有 利用 载波 信号 来 
影响 波形 的 输出 。 下 面 介绍 2ASK 的 相干 解 调 。 


(2) 相干 解 调 


2ASK 的 相干 解 调 模 型 如 图 4-37 所 示 ， 与 模拟 信号 解 调 模型 的 不 同 
点 也 仅 在 于 多 了 一 个 采样 判决 郁 ， 原 因 同 上 。 图 4-37 中 的 yi (0 表示 的 也 
征 已 调 信号 。 和 网 4-37 中 同样 为 各 步 所 生成 的 信号 进行 了 标注 。 
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图 4-37 2ASK 相 干 解 调 模型 


图 4-38 所 示 的 也 是 前 面 介绍 的 一 个 二 进 制 单 极 性 调制 信号 ( 源 信 
号 ) 110010001010， 解 调 后 还 原 出 调制 信号 的 过 程 。 具 体 步 又 如 下 
(同时 参照 图 4-37) : 


1) 已 调 信号 yi (0 经 过 带 通 滤波 器 (主要 用 于 过 滤 掉 已 调 信 号 的 低 
频 和 高 频 干 扰 信 号 ) 后 得 到 图 中 的 a 波 。 这 与 非 相 干 解 调 步 又 是 一 样 
的 。 


2) a 波 再 与 载波 信号 cosout 在 乘法 如 中 进行 相 乘 得 到 b 波 。 对 比 b 和 
a 波 可 以 看 出 ， 它 不 仅 是 一 个 极 性 过 滤 ， 而 且 包 含 了 载波 的 频率 成 分 ， 


信和 号 更 强 ; 

3) b 波 再 经 过 低 通 减 波 器 后 就 得 到 了 c 波 。 这 里 的 低 通 滤波 器 用 于 
过 滤 pb 波 中 高 频 成 分 ， 仅 允许 符合 源 信和 号 频率 特性 的 波形 输出 ， 这 步 
与 “ 非 相 干 解 调 ?也 一 样 。 

4) 最 后 经 过 采样 判决 器 ， 对 连续 型 的 c 波 进行 采样 ， 还 原 出 原始 
的 离散 型 调制 信号 d， 这 步 也 与 “ 非 相干 解 调 ” 一 样 。 


图 4-38 2ASK 相 干 解 调 示例 


从 以 上 叙述 可 以 看 出 ， 非 相干 解 调和 相干 解 调 在 执行 步骤 上 唯一 
的 区 别 丈 旦 第 2 步 ， 相 干 解 调 借 助 了 载波 信号 ， 主 要 是 为 了 使 信号 得 到 
加 强 ， 更 便于 在 后 面 的 市 通 滤波 万 中 过 滤 。 


4.5.3 FSK 调制 与 解 调 


FSK (频率 键 控 ) 是 用 数字 基带 信号 去 控制 载波 的 频率 特性 来 传送 
言 轧 的 一 种 调制 方式 ， 但 它 仅 适用 于 双 极 性 数字 信号 。 它 把 信号 的 振 
幅 、 相 位 作为 常量 ， 而 把 频率 作为 变量 ， 通 过 频率 的 变化 来 实现 信和 号 
的 识别 。 如 数字 信号 的 “1” 码 用 频率 为 fi 的 载波 (载波 1) 来 传 
送 ,，“0” 码 用 频率 为 f, 的 载波 (载波 2) 来 传送 ， 相 当 于 载波 在 两 种 不 同 
频率 之 间 进 行 切换 ， 故 又 称 频 移 键 控 。 


1.2FSK 调 制 


在 二 进 制 数字 调制 中 ， 若 正弦 载波 的 频率 随 二 进 制 基带 信和 号 在 两 
个 频率 点 间 变 化 ， 则 产生 的 是 二 进 制 移 频 键 控 信 号 (2FSK 信 号 ) 。 
2FSK 信 号 的 产生 与 2ASK 信 和 号 的 产生 一 样 ， 从 原理 上 讲 ， 数 字 调 频 可 用 
模拟 调频 法 来 实现 ， 也 可 用 键 控 法 来 实现 。 既 可 以 采用 模拟 调频 电路 
来 实现 ( 称 为 2FSK 模 拟 法 调制 或 者 直接 调频 法 ， 是 利用 一 个 矩形 脉冲 
对 载波 进行 频率 调制 ，， 又 可 以 采用 数字 键 控 的 方法 来 实现 ( 称 为 
2FSK 键 控 法 调制 或 者 移 频 刍 控 法 ， 是 利用 受 控 的 矩形 脉冲 序列 控制 的 
开关 电路 对 两 个 独立 的 频率 源 进行 选 通 ) ,分别 如 图 4-39 和 图 4-40 所 
示 。S(b 为 调制 信号 ，Srsx (t) 为 已 调 的 2FSK 信 和 号。 


D2FSK(D 


模拟 调频 融 


图 4-39 ”2FSK 模 拟 法 调制 模型 


开关 电路 


S(D) 


图 4-40 2FSK 键 控 法 调制 模型 


所 谓 “ 直 接 调频 法 ”"， 就 是 用 数字 基带 矩形 脉冲 控制 一 个 振荡 器 的 
某 些 参数 ， 直 接 改变 振荡 频率 ， 使 输出 得 到 不 同 频率 的 已 调 信 号 。 用 
此 方法 产生 的 2FSK 信 号 对 应 着 两 个 频率 的 载波 ， 在 码 元 转换 时 刻 ， 两 
个 载波 相位 能 够 保持 连续 ， 所 以 称 其 为 相位 连续 的 CPFSK 

(Continuous-Phase Frequency Shift Keying， 连 续 相 位 频 移 键 控 ) 信 
号 。 因 为 只 用 到 了 一 个 载波 ， 所 以 调制 后 的 Szpsx (0 信和 号 码 元 间 的 相位 
是 连续 的 ， 如 图 4-41 所 示 。 


Sorsg(D1) 


vVVVY 一 一 


信 码 1 调制 的 载波 频率 信 码 0 调制 的 载波 频率 
图 4-41 相位 连续 的 Sypsk (0 信号 


频率 键 控 法 又 称 为 频率 转换 法 ， 是 用 数 子 短 形 脉冲 控制 电子 开 
天， 使 电子 开关 在 两 个 独立 的 振荡 如 (产生 两 种 不 同 频率 的 载波 fi 和 了 
) 之 间 进 行 转换 ， 从 而 在 输出 端 得 到 不 同 频率 的 已 调 信号 。 由 于 产生 fi 
和 f, 载 频 是 由 两 个 独立 的 振荡 器 实现 的 ， 所 以 码 元 间 的 相位 不 一 定 是 
连续 的 ， 如 图 4-42 所 示 。 这 种 方法 的 特点 是 转换 速度 快 、 波 形 好 、 频 率 
稳定 度 高 、 电 路 不 其 复杂 ， 在 实用 中 可 以 用 一 个 频率 合成 器 代替 两 个 
独立 的 振荡 器 ， 再 经 分 频 链 进 行 不 同 的 分 频 ， 也 可 得 到 2FSK 信 和 号。 


Sorsg(1) 


信 码 1 对 载波 1 调制 的 频率 信和 码 0 对 载波 2 调制 的 频率 


图 4-42 相位 不 连续 的 S>rsk (0 信号 


2FSK 信 号 波 可 看 做 两 个 2ASK 信 和 号 波 的 合成 ， 信 和 码 1 和 0 分 别 调制 不 
同 频率 的 载波 。 但 因为 2FSK 调 制 的 是 双 极 性 数字 信号 ， 所 以 我 们 可 以 


把 一 个 单 极 性 2ASK 调 制 信号 分 成 两 个 互 反 的 信号 (否则 原来 单 极 性 信 
号 中 的 0 码 无 法 对 载波 进行 调制 ) 。 


图 4-43 所 示 就 是 源 信号 码 字 为 1011001 的 两 个 互 反 的 信号 s(t) 和 5 
波形 。 然 后 用 这 两 路 信号 作为 调制 信和 号， 分 别 对 两 个 不 同 频率 的 载波 
进行 调制 ， 如 图 4-44 所 示 。 其 中 cj (t) 和 和 c, (t) 分 别 代表 两 个 不 同 的 载波 ， 
si (和 so (0 是 s(t) 和 5() 这 两 路 调制 信号 分 别 对 ci (0 和 cv, (t) 载 波 进行 
2ASK 调 制 后 的 波 ; 再 把 s; (t) 和 so (0 这 两 路 信和 号 进行 县 加 就 得 到 了 最 终 
的 已 调 信号 2FSK 。 
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图 4-44 2FSK 调 制 示 例 
2.2FSK 解 调 


2FSK 信 号 的 解 调 方法 很 多 ， 如 鉴 频 法 、 过 零 检 测 法 、 非 相干 解 调 
法 ( 义 称 滤波 检测 法 ) 和 相干 解 调 法 〈 又 称 差分 检 波 法 ) 。 这 里 仅 介 
绍 相干 解 调 、 非 相干 解 调和 过 零 检测 这 三 种 2FSK 解 调 方法 。 


(1) 相干 和 非 相 干 2FSK 解 调 


2FSK 信 号 的 非 相干 解 调 (也 称 包 络 检测 法 ) 模型 如 图 4-45a 所 示 ， 
其 可 视 为 由 两 路 2ASK 解 调 电 路 组 成 (比较 图 4-35) 。 这 里 的 两 个 带 通 


滤波 器 (带宽 相同 ， 丝 为 相应 的 2ASK 信 号 带宽 ; 但 中 心 频率 不 同 ， 分 
别 为 fi 和 f。 ) 起 分 路 作用 ， 用 以 分 开 两 路 2ASK 信 号 ， 经 包 络 检测 (这 
里 的 “ 包 络 检测 ? 惑 是 检测 出 信号 的 频率 变化 ， 不 管 幅度 和 相位 特性 ) 

后 分 别 取出 互 反 的 s(D 及 (0) 两 路 信号 ， 采 样 判 决 器 起 比较 器 的 作用 ， 
通过 把 两 路 包 络 信 和 号 同时 送 到 采样 判决 卓 进 行 比较 ， 束 可 以 判决 输出 
基带 数字 信号 。 现 把 上 支 路 s(t) 和 下 支 路 sO 的 采样 值 分 别 用 Vi 、V2 表 
示 ， 若 采样 判决 器 的 判决 准则 为 Vi >V。 ， 则 输出 信 码 1; Vi <V。， 则 
输出 信 码 0 。 
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a ) 非 相 干 解 调 
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b ) 相干 解 调 


图 4-45 相干 和 非 相 干 2FSK 解 调 模 型 


图 4-46 所 示 的 是 一 个 基带 数字 信号 11001000101 经 过 2FSK 调 制 后 的 
2FSK 信 和 号 通过 非 相 干 解 调 方法 还 原 出 数字 基带 信号 的 波形 变化 图 。 其 
中 的 路 检 波 和 了 f 路 检 波 分 别 代表 两 路 2FSK 信 号 在 经 过 两 个 频率 不 同 
的 带 通 滤波 器 后 输出 的 波形 ，s(t) 和 3() 分 别 代表 从 两 个 带 通 滤波 器 输 
出 的 信号 再 经 过 包 络 检 波 器 后 输出 的 波形 ; 最 后 在 采样 判决 器 上 进行 
采样 〈 两 路 信号 的 采样 电压 值 分 别 用 Vi; 和 V, 表示 ) 和 判决 ， 若 V1 >V， 
则 输出 信 码 1， 若 Vi <Vs。 则 输出 信 码 0。 这 样 就 可 以 还 原 出 原始 的 数字 


2FSK 信号 和 


| | 三 / | \ 六 采样 值 信 
$1(D) 
上 采样 值 万 
-i 
采样 判定 | | | | 


图 4-46 非 相 干 2FSK 解 调 示 例 


相干 解 调 2FSK 的 模型 如 图 4-45b 所 示 。 图 中 的 两 个 市 通 滤波 万 起 分 
路 作用 。 它 们 的 输出 分 别 与 相应 的 同步 相干 载波 相 乘 ， 再 分 别 经 低 通 
滤波 紫 滤 挥 二 倍 频 信号 ， 取 出 仿 基 市 数 子 信息 的 低频 信和 号， 采样 判决 
如 在 采样 脉冲 到 来 时 对 两 个 低频 信号 的 采样 值 进行 比较 判决 (判决 规 
则 与 上 面 介 绍 的 非 相 干 解 调 ) 即 可 还 原 出 基带 数字 信和 号。 


(2) 过 和 雪 检 测 法 


单位 时 间 内 信和 号 经 过 零点 的 次 数 多 少 ， 可 以 用 来 衡量 频率 的 高 
低 。 数 字 调 频 波 的 过 零点 数 随 不 同 载 频 而 异 ， 故 检 出 过 零点 数 可 以 得 
到 关于 频率 的 差异 ， 这 束 写 过 夫人 怜 测 法 的 基本 思想 。 过 有 零 俭 测 法 2FSK 
解 调 模型 如 图 4-47 所 示 。 各 步 的 输出 波形 如 图 4-48 所 示 。 下 面具 体 解释 
这 些 步 台 ,但 是 具体 的 实现 方法 在 此 我 们 不 做 人 研究。 


图 4-47 过 零 检测 法 2FSK 解 调 模型 
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图 4-48 2FSK 过 零 检 测 法 解 调 示例 
1) 2FSK 输 入 信号 a 经 放大 、 限 幅 后 产生 和 矩形 脉冲 信号 b 。 


2) b 信 号 经 微分 及 整流 后 形成 与 频率 变化 相应 的 尖 脉 冲 序列 (分 
别 对 应 信号 c 和 d) ， 这 个 序列 束 代 表 着 调频 波 的 过 零 上 筷 。 


3) d 尖 脉冲 再 触发 一 脉冲 发 生 器 ， 变 换 成 具有 一 定 宽度 的 矩形 波 
e。 该 矩形 波 的 直流 分 量 便 代 表 着 信和 号 的 频率 ， 脉 冲 越 密 ， 直 流 分 量 越 
大 ， 反 映 着 输入 信和 号 的 频率 越 高 。 


4) e 拢 形 波 经 低 通 滤波 器 就 可 得 到 脉冲 波 的 直流 分 量 f。 这 样 就 完 
成 了 频率 -幅度 转换 ， 再 根据 直流 分 量 幅度 上 的 区 别 还 原 出 数字 信 
号 “1* 和 “0”。 


4.5.4 PSK 调 制 与 解 调 


PSK 〈 相 位 键 控 ) 是 利用 双 极 性 数字 基带 信号 对 载波 相位 进行 控制 
来 传送 信息 的 一 种 调制 方式 ， 也 束 是 用 载波 的 不 同 相 位 来 表示 信号 的 
信 码 。 我 们 知道 ， 如 果 两 个 频率 相同 的 载波 同时 开始 振荡 ， 这 两 个 频 
率 同 时 达到 正 最 大 值 ， 同 时 达到 零 值 ， 同 时 达到 负 最 大 值 ， 此 时 它们 
束 处 于 “ 同 相 ?状态 ， 如 采 一 个 达到 正 最 大 值 时 ， 必 一 个 达到 负 最 大 
值 ， 则 称 为 " 反 相 ”。 一 般 把 信号 振荡 一 次 (一 周 ) 作为 360"。 如 果 一 个 
波 比 另 一 个 波 相关 半 个 周期 ， 我 们 说 两 个 波 的 相位 兰 180"， 也 融 是 反 
相 。 因 此 数字 调 相 束 古 让 载波 在 两 种 相位 间 切 换 ， 故 义 称 相 移 键 控 。 


如 果 调 制 信号 是 二 进 制 数字 基 市 信号 ， 则 这 种 PSK 称 为 2PSK 。 
PSK 分 为 绝对 相位 键 控 (Absolute Phase Shift Keying，APSK) 和 相对 
相位 键 控 (或 者 “差分 相位 键 控 ”，Differential Phase Keying，DPSK) 两 
种 。 因 为 通常 采用 的 就 是 绝对 相位 键 控 方式 ， 所 以 APSK 通 常 表示 为 
PSK 。 


1. 绝 对 相位 调制 与 解 调 


绝对 相位 键 控 〈 通 常 就 表示 为 PSK， 对 应 的 二 进 制 绝对 相位 键 控 就 
为 2PSK) 是 用 未 调 载波 的 相位 为 基准 相位 的 PSK， 此 时 在 接收 系统 
必须 有 一 个 与 发 送 系 统 相 同 的 基准 相位 作为 参考 ， 以 识别 接收 到 的 


是 “1” 码 还 是 “0” 码 。 调 制 规则 是 : 当 已 调 载波 相位 与 基准 相位 相差 0" 时 
发 送信 码 “1”， 当 已 调 载波 相位 与 基准 相位 相差 180°? 时 发 送信 码 “0”。 


(1) 2PSK 调 制 


2PSK 信 和 号 的 产生 也 有 模拟 调 相 法 和 键 控 调 相 法 两 种 ， 模 拟 调 相 法 
是 把 2?PSK 看 做 双 极 性 不 归 堆 码 基 市 信号 的 数字 调幅 2ASK， 即 基 市 信和 号 
与 载波 的 乘积 ， 其 调制 模型 如 图 4-49 所 示 ; 而 键 控 调 相 法 是 通过 载波 在 
两 种 不 同 相 位 之 间 进 行 切换 而 进行 的 ， 其 调制 模型 如 图 4-50 所 示 。 其 中 
s(t) 为 数字 基带 信号 ，cosQc (0 为 载波 信号 ，S>psK (0 为 已 调 2PSK 信 号。 
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图 4-49 模拟 调 相 法 调制 模型 
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图 4-50 ” 键 控 调 相 法 调制 模型 


图 4-51 所 示 是 一 个 二 进 制 数字 基带 信号 1011001 的 2PSK 的 调制 示 
例 ， 其 中 s(t) 就 是 数字 基带 信号 的 矩形 脉冲 波形 ，c(t) 是 一 个 正统 载波 波 
形 ，2PSK 有 是 经 过 相位 调制 后 的 已 调 波形 。 从 图 4-50 中 可 以 看 出 ， 当 信 
码 为 1 时 ，2PSK 波 形 的 相位 与 载波 一 样 ， 而 当 信 码 为 0 时 ，2PSK 的 相位 
与 载波 相位 相反 。 这 种 调制 原理 很 好 理解 。 


s(7) 


c(f) 


2PSK 


图 4-51 2PSK 调 制 示 例 
(2) 2PSK 解 调 


2PSK 信 号 的 解 调 通常 都 是 采用 “相干 解 调 法 ”， 其 解 调 模型 如 图 4- 
52 所 示 。 在 解 调 过 程 中 需要 用 到 与 接收 的 2PSK 信 号 同 频 、 同 相 的 相干 
载波 。 如 图 4-53 所 示 的 是 一 个 2PSK 相 干 解 调 示例 。 
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图 4-52 2PSK 相 干 解 调 模型 


在 图 4-53 所 示 的 示例 中 ，a 是 2PSK 已 调 信号 经 过 带 通 滤波 器 后 得 到 
的 信和 号 波 (融通 滤波 如 主要 用 来 过 滤 低 频 和 高 频 干扰 成 分 i ; b 是 用 来 
与 2PSK 信 号 相 乘 的 本 地 相干 载波 ，c 是 a 与 b 经 过 相 乘 后 得 到 的 信号 波 ; 
d 是 c 信 号 波 经 过 低 通 滤波 器 (去 除 高 频 成 分 | 后 得 到 的 信号 波 ;，e 是 d 
信号 经 过 数字 采样 后 得 到 的 信和 离散 矩形 脉冲 ，f 是 经 过 再 生 器 放大 后 得 
到 的 数字 脉冲 信号 ， 这 束 是 原始 的 基带 数字 信和 号。 


电 平 
wi oA 
ER WX NU Ny NX \ Wh SA Wy 时 间 


:AAAAAA A 
RA WA “A 村 要 EY Ey 时 间 
ne wl A 
-者 相 乘 可 有 MAA WA Wf 
低 通 滤波 4 0 /NN /NN 
一 和 一 和 一 


采样 信号 。 0 | 
| | | | 


本 地 载波 b 


时 间 


时 间 


再 生 信 号 f O | | | | | > 
时 间 


图 4-53 2PSK 相 干 解 调 示例 


相干 解 调 需要 一 个 与 发 送 端 调制 时 所 用 的 载波 同 频 同 相 的 本 地 载 
流 。 但 此 载波 是 由 接收 端的 载波 提取 电路 提取 。 这 里 出 现 了 一 个 问 
题 ， 如 果 两 端 载波 存在 频率 和 相位 偏差 ， 就 可 能 出 现 解 调 错误 ， 如 原 
来 所 有 的 “1 码 都 变 成 了 “0? 码 ， 所 有 的 “0? 码 都 要 成 了 “1? 码 。 如 图 4-54 
所 示 的 左 、 上 图 分 别 是 采用 与 发 送 端 载波 相位 相同 (相差 为 0 、 相 反 


\ 相 差 为 180") 的 本 地 载波 2PSK 调 制 结 果 ， 从 中 可 以 看 出 ， 它 们 的 结 
果 (f 波 形 ) 是 完全 相反 的 。 


MA 
of VW VVVYV 时 间 


0 相 载 波 b n 
~ “IVVVVYVVVV 

-者 相 乘 c 0 
时 间 
低 通 滤波 d oOo 
时 间 


采样 信号 。 0 


再 生 信号 f 0| | 二 一 


时 间 


图 4-54 采用 0° 相 差 和 180° 相 差 本 地 载波 解 调 的 结果 比较 
2. 相 对 相位 调制 与 解 调 


为 了 解决 绝对 相位 调制 中 的 相位 倒置 问题 ， 在 进行 数字 调 相 之 前 
先进 行 差 分 编码 ， 再 对 差分 码 进行 二 元 数字 调 相 ， 这 束 是 这 里 要 介绍 
的 二 元 差分 相位 调制 (2DPSK) 。 


2DPSK 不 是 利用 载波 相位 的 绝对 数值 传送 数字 信息 ， 而 是 用 前 后 
码 元 的 相对 载波 相位 值 来 传送 数字 信息 。 所 谓 相 对 载波 相位 是 指 本 码 
元 初 相位 与 前 一 码 元 初 相位 之 差 ， 即 相位 偏 黎 ， 并 规定 ， 当 相位 偏 移 
值 为 O 时 输出 信 码 9， 相位 偏 移 180°? 时 输出 信 码 1 。 


(1) 2DPSK 调 制 


2DPSK 信 和 号 的 产生 过 程 : 首先 对 数字 基 市 信号 进行 差分 编码 ， 即 
由 绝对 码 变 为 相对 码 〈 差 分 码 ) ， 然 后 再 进行 绝对 调 相 。 所 以 ， 
2DPSK 的 调制 原理 与 ?PSK 的 调制 原理 类 似 ， 也 征用 二 进 制 基 市 信号 作 
为 模拟 开关 的 控制 信号 轮流 选 通 不 同 相 位 的 载波 来 完成 2DPSK 调 制 ， 
不 同 的 仅 是 先 要 对 数字 基带 信号 进行 差分 编码 。 其 调制 模型 如 图 4-55 所 
示 ， 与 如 图 4-50 所 示 的 绝对 调 相 模型 非常 相似 。 


开关 电路 
正弦 波 发 生 珍 


COS CDJ 1 
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,ppsk(D 


cos O .1 个 


图 4-55 2DPSK 调 制 模型 


图 4-56 所 示 的 十 一 个 2DPSK 调 制 示 例 。 图 中 首先 是 输入 的 数 子 基 
带 信号 (绝对 码 ) ， 然 后 通过 差分 变换 后 得 到 “相对 码 ” 信 号 波 。 这 里 
的 “相对 码 ” 有 一 个 计算 规划 ， 即 模 2 逻 辑 加 法 运算 : 


bn 一 qn 四 bl 


式 中 bi 为 当前 码 的 相对 码 ，a 为 当前 码 的 绝对 码 ，bu1 是 bu 的 前 
一 个 码 元 的 相对 码 ， 最 初 的 pl 可 任意 设 定 。 模 2 逻辑 加 运算 规则 是 : 
0+0=0，0+1=1，1+0=1，1+1=0， 也 就 是 只 要 双方 值 不 一 样 时 结果 才 是 
1， 相 同 则 结果 为 0。 


] 0 0 ] 0 ] ] 0 
绝对 码 (a,) | | ] ] ] | 
] ] ] 0 0 ] ] 0 


相对 码 (b,) ] | ] | 


图 4-56 2DPSK 调 制 示例 


下 面 来 分 析 一 下 图 4-56 所 示 的 示例 ， 假 设 最 初 的 bl 相对 码 为 0。 


第 一 个 码 元 的 绝对 码 (al ) 为 1， 因 为 最 初 的 bo 相对 码 为 0， 所 以 


它们 模 2 加 运算 的 结果 为 1， 即 bj =1 。 


第 二 个 码 的 绝对 码 (a ) 为 0， 因 为 bl 相对 码 前 面 已 算出 为 1， 


以 它们 模 2 加 运算 的 结果 也 为 1， 即 by =1。 


第 三 个 码 的 绝对 码 (a3 ) 为 0， 因 为 b 相对 码 前 面 已 算出 为 1， 


以 它们 模 2 加 运算 的 结果 同样 为 1， 即 bs =1 。 


第 四 个 码 的 绝对 码 (ay ) 为 1， 因 为 bs 相对 码 前 面 已 算出 为 1， 


以 它们 模 2 加 运算 的 结果 为 0， 即 b4 =0 。 


第 五 个 码 的 绝对 码 (as ) 为 0， 因 为 by 相对 码 前 面 已 算出 为 0， 


以 它们 模 2 加 运算 的 结果 为 0， 即 bs =0。 


第 六 个 码 的 绝对 码 (a6 ) 为 1， 因 为 bs 相对 码 前 面 已 算出 为 0， 


以 它们 模 2 加 运算 的 结果 为 1， 即 be =1。 


第 七 个 码 的 绝对 码 (ay ) 为 1， 因 为 be 相对 码 前 面 已 算出 为 1， 


以 它们 模 2 加 运算 的 结果 为 0， 即 by =0。 


第 八 个 码 的 绝对 码 (az ) 为 0， 因 为 by 相对 码 前 面 已 算出 为 0， 


以 它们 模 2 加 运算 的 结果 为 0， 即 bs =0。 


这 样 最 终 就 得 出 数字 基带 信号 10010110 的 相对 码 为 11100100 。 


所 


所 


所 


所 


I 


所 


得 到 了 相对 码 ， 后 面 载波 的 变化 〈 也 就 是 2DPSK 信 号 的 相位 ) 惑 
很 容易 了 ， 因 为 它 也 有 一 个 与 相对 码 对 应 的 计算 规则 ， 那 就 是 : 当 相 
对 码 “1” 时 ， 调 制 信和 号 的 相位 与 原 载 波 一 样 ， 当 相对 码 为 “<0” 时 反 转 
180°。 这 样 就 很 容易 画 出 图 4-56 所 示 最 后 的 2DPSK 波 形 。 


(2) 2DPSK 解 调 


2DPSK 解 调 最 常用 的 方法 就 是 极 性 比较 法 (相干 解 调 ， 和 相位 比 
较 法 (差分 解 调 ， 两 种 ， 其 解 调 模 型 分 别 如 图 4-57 和 图 4-58 所 示 。 


d 
低 通 滤波 天 采样 判决 需 


图 4-57 2DPSK 相 干 解 调 模 型 


\ 


数字 基带 信和 号 


图 4-58 2DPSK 差 分 解 调 模型 


2DPSK 解 调 是 2DPSK 调 制 的 敢 过 程 。 前 面 我 们 说 了 ，2DPSK 调 制 
过 程 中 要 对 绝对 码 (也 就 是 “数字 基带 信和 号”) 进行 差分 处 理 ， 将 其 转 
换 成 相对 码 ， 然 后 再 进行 绝对 相位 调制 。2DPSK 解 调 则 需要 先 把 
2PDSK 已 调 信 号 转换 成 相对 码 ， 然 后 再 把 相对 码 转 换 成 绝对 码 ， 这 个 


绝对 码 吏 是 要 解 调 出 来 的 数字 基 市 信号 。 下 面 仅 对 相干 解 调 法 进行 介 


绍 。 


图 4-59 所 示 是 一 个 2DPSK 相 干 解 调 示例 。 图 中 a 为 2DPSK 已 调 信号 


PE 


高 频 成 分 得 到 d 信 号 ; d 信 和 号 经 过 定时 采样 后 得 到 离散 的 二 进 制 脉冲 信 
号 e (这 就 相当 于 抽取 到 了 调制 信号 中 的 “相对 码 >， 本 示例 中 为 
111001001) ， 然 后 再 逆差 分 变换 就 得 到 了 原始 的 数字 基带 信号 (也 就 
是 绝对 码 ， 本 示例 中 为 000101100) 。 


图 4-59 2DPSK 相 和 干 解 调 示 例 


这 里 从 相对 码 转换 成 绝对 码 的 计算 也 下 遵从 模 2 逻 和 辑 加 运算 的 ， 运 
和 个 公 趟 为 : 


dn =b， ©® bi 


式 中 bs 和 bi 分 别 为 当前 相对 码 的 绝对 码 ， 以 及 前 一 个 相对 码 的 绝 
对 码 。 计 算 方 法 参见 前 面 介绍 的 2DPSK 调 制 中 的 绝对 码 与 相对 码 的 转 


换 ， 大 家 可 以 目 己 计算 验证 一 下 。 


因为 2DPSK 是 靠 相 邻 码 元 的 变化 与 否 来 决定 “1” 码 和 “0” 码 的 ， 所 以 
不 论 0 相 位 还 是 180°* 相 位 ， 相 邻 码 元 的 变化 关系 古 一 样 的 。 也 正 因 如 
此 ， 接 收 端 无 论 用 0 相 载 波 还 是 180° 相 位 载波 解 调 ， 尽 管 得 到 的 差分 码 
不 同 ， 但 经 差分 逆 变 换 后 ， 二 者 得 到 的 结论 完全 相同 。 


4.6 物理 层 传输 介质 


传输 介质 又 称 传输 媒介 ， 就 是 数据 传输 系统 中 在 发 送 磊 和 接收 顷 
之 间 的 物理 线路 。 在 计算 机 网 络 中 ， 有 多 种 可 用 于 实际 数据 传输 的 传 
输 介质 ， 每 一 种 都 有 它 目 己 的 特性 ， 包 括 人 带宽、 延迟 、 工 作 频 率 等 。 
这 么 多 传输 介质 总 体 上 可 分 为 以 下 两 大 类 : 


口 导 辣 性 传输 介质 ， 也 区 是 信号 被 固定 汽 着 信道 的 一 个 或 多 个 方 
向 进行 传输 的 介质 ， 特 指 有 线 计算 机 网 络 中 所 使 用 的 传输 介质 ， 如 双 
绞 线 、 同 轴 电 缆 和 光纤 等 。 


口 非 导 同性 传输 介质 : 也 就 是 信号 在 信道 中 的 传输 没有 固定 方 回 
的 传输 介质 ， 如 空气 中 的 无 线 电 波 、 电 磁 波 ， 通 肖 是 特 指 在 各 种 无 线 
网 络 (如 WLAN、 卫 星 通信 ) 中 所 使 用 的 传输 介质 。 


4.6.1 ” 导 癌 性 传输 介质 


通过 前 面 的 介绍 ， 我 们 知道 ， 有 线 计算 机 网 络 中 的 传输 介质 都 是 


导向 性 传输 介质 ， 主 要 有 双 绞 线 电 绕 、 同 轴 电 缆 和 光纤 电缆 三 种 。 本 
向 大 家 简单 介绍 这 三 种 导 问 传输 介质 。 


1. 双 统 线 (Twisted Pair) 


双 绥 线 在 我 们 的 计 机 网 络 ， 竺 别 生 局域网 连接 中 应 用 最 为 广泛 ， 
这 主要 得 益 于 它 的 廉价 性 和 非常 不 错 的 可 用 性 。 把 两 根 互 相 绝 经 的 铀 
导线 并 排放 在 一 起 ， 然 后 用 规则 的 方法 弘 合 起 来 号 构成 了 双 绞 线 ， 如 


图 4-60 所 示 。 


图 。 4-60” 双 绞 线 


双 绞 线 最 早 使 用 在 电话 交换 系统 中 〈 那 时 主要 是 三 类 或 以 前 版 本 
的 ) ， 后 来 才 移 植 到 计算 机 网 络 中 ， 当 然 对 应 的 材质 和 标准 都 不 一 
样 。 在 计算 机 网 络 中 使 用 的 双 绞 线 可 分 为 屏蔽 双 纹 线 (Shielded 
Twisted Pair，STP) 和 非 屏 蔽 双 绞 线 (Unshielded Twisted Pair，UTP) 
两 大 类 。STP 是 以 金属 钉 进 行 屏 菩 包 焉 的 ， 以 减少 心 线 则 的 干扰 和 串 
首 ; 而 UTP 双 绞 线 则 没有 这 一 层 屏 蔽 用 的 金属 钉 ， 分 别 如 图 4-61 所 示 。 


这 就 是 用 
于 屏 菩 的 
金属 箔 


a) 屏蔽 双 绞 线 b) 无 屏 殴 双 绞 线 


图 4-61 STP 和 UTP 双 绞 线 


除 此 之 处 ， 根 据 EIA/TIA 568 标 准 规定 的 双 绞 线 电 气 性 能 ， 计 算 机 
网 络 所 用 的 双 绞 线 还 有 多 种 不 同 的 划分 ， 如 3 类 线 、4 类 线 、5 类 线 、 超 
5 类 线 、6 类 线 、 超 6 类 线 ， 一 直到 最 新 的 7 类 线 。 类 型 数字 越 大 ， 版 本 
越 新 、 技 术 越 先进 、 市 宽 也 越 宽 ， 当 然 价 格 也 越 贯 了 。 这 些 不 同类 型 
的 双 绥 线 标注 方法 息 这 样 规定 的 : 如 条 二 标准 类 型 则 按 “catx" 方 式 标 
注 ， 如 常用 的 5 类 线 ， 则 在 线 的 外 包皮 上 标注 为 “cat5”"， 注 意 字 母 通 常 
征 小 写 ， 而 不 是 大 写 。 而 如 采 是 改进 版 ， 束 核 *xe"”， 如 超 5 类 线 融 标 广 
为 “5e”， 同 样子 母 古 小 写 ， 而 不 是 大 写 。 


双 绞 线 技术 标准 是 在 美国 通信 工业 协会 (TIA) 的 EIA/TIA-568A 或 
EIA/TIA-568B 标 准 中 定义 的 ， 具 体 如 下 : 


口 1 类 线 : 是 ANSLEIA/TIA-568A 标 准 中 最 原始 的 非 屏 蔽 双 绞 铜 线 
电缆 ， 但 它 开 发 之 初 的 目的 不 是 用 于 计算 机 网 络 数据 通信 的 ， 而 是 用 
于 电话 语音 通信 的 。 


口 2 类 线 : 是 ANSI/EIA/TIA-568A 和 ISO 2 类 /A 级 标准 中 第 一 个 可 用 
于 计算 机 网 络 数据 传输 的 非 屏 蔽 双 绞 线 电 比 ， 工 作 频 率 为 1MHz， 传 输 
速率 最 高 为 4Mbps。 主 要 用 于 以 前 的 令 牌 总 线 网 络 。 


口 3 类 线 : 是 ANSI/EIA/TIA-568A 和 ISO 3 类 /B 级 标准 中 专用 于 
10BaseT 以 太 网 络 的 非 屏蔽 双 绞 线 电 比 ， 工 作 频 率 为 16MHz， 传 输 速 度 


最 高 为 0Mbps。 


口 4 类 线 : 是 ANSIEIA/VTIA-568A 和 ISO 4 类 /C 级 标准 中 用 于 令 牌 环 
网 络 的 非 屏 蔽 双 绞 线 电 统 ， 工 作 频 率 为 20MHz， 传 输 速 度 最 高 为 
16Mbps ° 


口 5 类 线 : 是 ANSIEIA/TIA-568A 和 ISO 5 类 /D 级 标准 中 用 于 运行 
CDDI (CDDI 是 基于 双 绞 铜 线 的 FDDI 网 络 ) 和 快速 以 太 网 的 非 屏 蔽 双 
绞 线 电缆 ， 工 作 频 率 为 100MHz， 传 输 速 度 最 高 为 100Mbps。 


口 超 5 类 线 : 是 ANSLIEIA/TIA-568B.1 和 ISO 5 类 /D 级 标准 中 用 于 运 
行 快 速 以 太 网 的 非 屏 蔽 双 绞 线 电 绕 ， 工 作 频 率 也 为 100MHz， 传 输 速 度 
最 高 也 为 100Mbps。 与 5 类 线 相 比 ， 超 5 类 线 在 近 端 串扰 、 串 扰 总 和 、 衰 
减 和 信 噪 比 这 四 个 主要 指标 上 都 有 较 大 的 改进 。 


口 6 类 线 : 是 ANSILEIA/TIA-568B.2 和 ISO 6 类 /E 级 标准 中 规定 的 一 
种 非 屏 滞 双 绞 线 电 绕 ， 主 要 应 用 于 快速 以 太 网 和 千 兆 以 太 网 中 。 它 的 
工作 频率 可 达 200~250MHz， 是 超 5 类 线 带 宽 的 2 倍 ， 最 高 传输 速度 可 达 


到 1000Mbps 。 


口 超 6 类 线 : 是 六 类 线 的 改进 版 ， 同 样 是 ANSLEIA/TIA-568B.2 和 
ISO 6 类 /E 级 标准 中 规定 的 一 种 非 屏蔽 双 绞 线 电 绕 ， 主 要 应 用 于 千 兆 网 
络 中 。 在 工作 频率 方面 与 6 类 线 一 样 ， 也 是 200~250MHz， 最 大 传输 速 


度 也 可 达到 1000Mbps， 只 是 在 串扰 、 衰 减 和 信 噪 比 等 方面 有 较 大 改 


重 。 


[二 


口 7 类 线 : 是 ISO 7 类 下 级 标准 中 最 新 的 一 种 双 绞 线 ， 主 要 为 了 适应 
万 兆 以 太 网 技术 的 应 用 和 发 展 。 但 它 不 再 是 一 种 非 屏蔽 双 绞 线 了 ， 而 
是 一 种 屏蔽 双 绞 线 ， 工 作 频 率 至 少 可 达 500MHz， 又 是 6 线 和 超 6 类 线 的 
2 倍 以 上 ， 最 高 传输 速率 为 10Gbps。 


说 明 ”在 北美 标准 中 ， 双 绞 线 及 其 他 一 些 网 络 传输 介质 的 标准 通 


征 由 以 下 三 个 主要 的 组 织 制定 的 : 


DANSI (American National Standard Institute， 美 国 国 家 标准 化 组 


DTIA (Telecommunication Industry Association， 电 信 工 业 联 合 


DEIA (Engineering Institute Association， 工 程 技术 协会 ) 


且 通 常情 况 下 ， 其 中 的 一 个 组 织 颁 布 一 个 标准 ， 再 由 另外 两 个 组 
织 进 行 修正 。 在 欧洲 ， 电 缆 标 准 由 CENELEC (欧洲 电子 技术 标准 委员 
会 ) 发 布 ， 该 组 织 的 成 员 来 自 于 欧洲 19 个 国家 的 电子 技术 委员 会 。 
ISO/IEC 将 采纳 CENELEC 的 标准 作为 ISO/IEC 的 标准 。 


2. 同 轴 电 统 


同 轴 电 缆 (Coaxial Cable) 的 得 名 也 与 它 的 结构 相关 。 它 用 来 传递 
言 息 的 一 对 导体 是 按照 一 层 圆 简 式 的 外 导体 套 在 内 导体 〈 一 根 细心 ) 
外 面 ， 两 个 导体 间 用 绝缘 材料 互相 隔离 的 结构 制造 的 。 外 层 导 体 和 中 
心 轴 世 线 的 圆心 在 同一 个 轴 心 上 ， 所 以 称 为 同 轴 电 缆 ， 如 图 4-62 所 示 。 
其 剖面 如 图 4-63 所 示 。 
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图 4-62 同 轴 电 缆 
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外 层 
图 4-63 同 轴 电 缆 剖 面 图 


广泛 使 用 的 同 轴 电 绕 有 两 种 : 一 种 为 508 同 轴 电 缆 ， 用 于 数字 信和 号 
的 传输 ， 即 基带 同 轴 电 缆 ; 另 一 种 为 758 同 轴 电 缆 ， 用 于 宽带 模拟 信和 号 
的 传输 ， 即 宽 融 同 轴 电 缆 。 现 行 以 太 网 同 轴 电 缆 的 接 法 有 两 种 : 直径 
为 0.4cm 的 RG 一 一 11 粗 同 轴 电 红 ， 采 用 请 和 孔 接 头 接 法 ， 直 径 为 0.2cm 的 
RG 一 一 58 细 同 轴 电 绕 ， 采 用 IT 形 头 接 法 。 这 两 种 接头 如 图 4-64 所 示 。 


a) 粗 同 轴 电线 接头 b) 细 同 轴 电 缆 接 头 


图 4-64 粗 / 细 同 轴 电 缆 接 头 


粗 同 轴 电 缆 符 合 10BASE5 介 质 标准 ， 使 用 时 需要 一 个 外 接收 发 器 
(如 图 4-64a 所 示 ) 和 收发 器 电缆 ， 单 段 最 大 长 度 为 500m， 可 靠 性 强 ， 
最 多 可 接 100 台 计算 机 ， 两 台 计 算 机 的 最 小 间距 为 2.5m。 细 同 轴 电 缆 按 
10BASF 一 一 2 介质 标准 直接 连 到 网 卡 的 T 形 关连 接 右 ( 即 BNC 连 接 句 ， 
如 图 4-64b 所 示 ) 上 ， 单 段 最 大 长 度 为 185m， 最 多 可 接 30 个 工作 站 ， 最 
小 站 间距 为 0.5m。 这 些 在 组 网 时 一 定 要 注意 ， 当 然 现 在 用 这 种 电缆 组 
网 已 基本 上 没有 了 。 


3 多 秆 


光纤 的 完整 名 称 为 光 导 纤维 ， 是 用 石英 玻璃 、 塑 料 或 晶体 等 对 某 
个 波长 范围 透明 的 材料 制造 的 能 传输 区 的 纤维 。 而 我 们 有 时 听 到 的 “学 
绕 * 是 含有 光纤 并 符合 现场 实际 使 用 要 求 的 光 、 机 机 和 环境 规 施 的 线 
缆 ， 由 光纤 、 加 强 件 和 外 护 层 等 组 成 。 按 光缆 中 所 包含 的 光纤 数量 又 
分 为 单 世 、 双 世 、 多 芯 几 种 。 图 4-65 所 示 即 为 单 世 光缆 和 多 忆 光 缆 结 
构 。 


a) 单 心 、 . 
9 塑料 外 套 
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心 光线 本 
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图 4-65 单 芯 和 多 芯 光 缆 及 其 结构 
光 传 输 系 统 由 三 部 分 组 成 ， 即 光源 、 传 输 介 质 和 检测 器 。 在 光纤 
的 一 端 放 上 光源 ， 另 一 端 放 上 检测 器 ， 就 构成 了 一 个 单 向 光 传 输 系 
统 。 光 纤 通 信 是 利用 光纤 传递 光 脉 冲 来 进行 数据 通信 的 。 通 常 是 一 个 
光 脉 冲 表示 二 进 制 中 的 一 个 1， 而 无 光 脉 冲 则 表示 二 进 制 中 的 一 个 0。 


光纤 的 分 类 标准 非 钊 多 ， 主 要 可 以 从 工作 波长 、 折 射 率 分 布 、 传 
输 模式 、 原 材料 和 制造 方法 进行 ， 下 面 介绍 几 种 主要 的 分 类 标准 。 


(1) 按 传输 模式 来 划分 


在 这 里 首先 要 搞 清 楚 的 就 是 什么 古 光 传输 模式 。 光 传输 模式 束 是 
光 信 号 照射 到 光纤 的 纤 必 以 及 从 光纤 包 层 上 反射 的 角度 ， 一 个 角度 就 


征 一 种 模式 。 根 据 光 纤 中 传输 模式 的 多 少 ， 可 分 为 单 模 光 纤 和 多 模 访 
纤 两 类 。 


单 模 光纤 (Single-Mode Fiber，SME) 


单 模 光 纤 是 一 种 只 用 来 传输 一 种 模式 光 〈 但 可 以 含有 多 种 波长 的 
光 ) 的 光纤 。 也 就 是 在 单 模 光 纤 中 所 传输 的 光照 射 纤 必 的 角度 和 从 包 
层 反 射 的 角度 是 一 样 的 ， 并 且 在 单 模 光 纤 中 是 没有 反射 的 ， 只 有 和 直 
射 ， 如 图 4-66a 所 示 。 


| 
ai 


a) 单 模 光纤 b) 多 模 光纤 


图 4-66 单 / 双 模 光纤 的 信号 传输 


单 模 光 纤 的 纤 忆 直径 一 般 很 小 〈 通 常 为 8~10hm， 交 缆 外 径 为 
125hm) ， 因 为 只 有 这 样 光纤 才 只 允许 与 光纤 轴 方 向 一 致 的 光线 通过 ， 
即 只 允许 通过 一 个 模式 的 光 。 单 模 光 纤 通 常 携带 一 个 波长 (通常 是 
1.31hm 或 1.55hm) 的 光 信 号 。 


因为 单 模 光 纤 完 全 避免 了 反射 ， 所 以 光 信 号 损耗 很 小 ， 适 合 于 长 
距离 的 光纤 通信 ， 如 目前 在 有 线 电视 中 采用 的 就 是 单 模 光 纤 。 


多 模 光 纤 (Multi-Mode Fiber，MME) 


与 单 模 光 纤 对 应 ， 多 模 光 统 束 是 可 以 在 一 根 光 纤 上 同时 传输 几 种 
模式 的 光 信 号 的 光纤 ， 如 图 4-66b 所 示 。 从 图 中 可 以 看 出 ， 这 些 光照 冉 
纤 必 的 角度 和 从 包 层 反射 的 角度 都 不 一 样 。 


多 模 光 纤 的 纤 心 直径 较 粗 〈 通 常 为 50hm 或 62.5hm， 光 缆 外 径 也 为 
125hm) 。 由 于 存在 反射 ， 光 信号 在 传输 过 程 中 会 有 损耗 ， 所 以 多 模 光 
纤 主 要 适用 于 短 距离 传输 ， 在 10Mbps 及 100Mbps 的 以 太 网 中 传输 ， 而 
于 1Gbps 千 兆 网 中 ， 多 模 光 纤 最 长 可 支持 2000m 的 传输 距离 ， 多 模 光 纤 
最 高 可 支持 550m 的 传输 距离 。 


(2) 按 纤 芯 直径 来 划分 

如 果 按 光纤 直径 大 小 来 分 的 话 ， 可 以 分 为 : 
口 缓 变型 多 模 光 纤 ，50/125 (pm) ; 

口 缓 变 增强 型 多 光纤 ，62.5/125 (pm) ; 

口 缓 变型 单 模 光 纤 ，8.3/125 (hm) 。 

(3) 按 光 纤 忆 折射 率 分 布 划分 

在 这 种 划分 标准 下 ， 光 纤 又 可 以 分 为 以 下 几 种 : 


阶 跃 型 光纤 (Step index fiber，SIF) 


阶 跃 型 光纤 又 称 突变 型 光纤 ， 目 前 ， 单 模 光 纤 多 属 此 类 ， 节 早 的 
多 模 光 纤 也 属 此 类 。 这 种 SIF 光 纤纤 心 的 折射 率 与 包 层 的 折射 率 成 阶 跃 
型 分 布 。 它 的 特点 古 忌 的 折 映 率 是 均匀 的 ， 在 心 和 包 层 之 间 的 分 界面 
上 ， 折 射 率 有 一 个 不 连续 的 阶 跃 性 突变 。 纤 心 直 径 为 50~100hm， 光 线 
以 曲折 形状 传播 ， 特 点 是 信号 畸变 大 。 


渐变 型 光纤 (Graded index fiber，GIF) 

渐变 型 光纤 又 称 梯度 光纤 ， 单 模 和 多 模 光 纤 都 有 此 类 型 。 其 特点 
是 纤 忆 中 心 的 折射 率 最 大 ， 沿 径 回 往外 逐步 变 小 ， 形 成 一 个 连续 渐变 
的 梯度 或 坡度 ， 最 后 达到 包 层 的 折射 率 。 渐 变型 光纤 的 纤 忆 直径 为 
50pkm， 光 线 以 正弦 形状 传播 ， 信 号 畸变 小 。 


单 模 环 形 光 纤 (Ring fiber) 


单 模 环形 光纤 折 冉 率 分 布 与 突变 型 光纤 相似 ， 纤 心 直 径 为 
8~12hm， 欧 线 以 直线 形状 沿 纤 必 中 心 轴线 方 癌 传播 。 因 为 光纤 只 能 传 
输 一 个 模式 ， 所 以 称 为 单 模 光 纤 ， 其 折射 率 最 高 ， 信 和 号 畸变 小 。 


单 模 W 形 光纤 (W-Fiber) 


单 模 W 形 光纤 又 称 双 包 层 光纤 ， 因 其 折射 率 分 布 像 W 形 而 得 名 。 
筷 的 横 截 面 也 分 为 三 个 区 域 ， 每 个 区 域内 的 折射 率 也 都 不 均匀 的 ， 
中 心 的 折射 率 最 高 ， 中 间 区 域 折 射 率 最 低 ， 最 外 面 区 域 折 射 率 介 于 两 


者 之 间 。 可 以 实现 10Gbps 容 量 的 100km 的 超大 容量 超 长 距离 的 信号 传 
送 o 


单 模 三 角 型 光纤 


单 模 三 角 型 光纤 的 纤 心 折射 率 分 布 曲 线 为 三 角形 ， 走 一 种 新 型 单 
模 光 纤 ， 适 用 于 密集 波 分 负 用 和 孤子 传输 的 长 距离 系统 。 


单 模 椭 贺 型 光纤 


单 模 椭圆 型 光纤 也 十 因 其 纤 心 折射 率 分 布 为 椭圆 型 而 得 名 。 这 种 
光纤 具有 双 折 射 特 性 ， 即 两 个 正 交 偶 振 模 的 传输 币 数 不 同 ， 适 用 于 长 
距离 传输 。 


(4) 按 光 纤 的 组 成 材料 分 


按 光纤 的 组 成 材料 可 分 为 : 石英 玻璃 光纤 (主要 材料 为 Si0， ) 、 
多 组 分 玻璃 光纤 〈 主 要 材料 为 SiO, 、Na O 和 CaO 等 氧化 物 ) 、 硅 酸 盐 
光纤 、 氢 化 物 光 纤 、 塑 料 包 层 玻璃 光纤 、 全 塑 光纤 、 溢 尽 光 纤 、 测 光 
光纤 、 尾 光 光 纤 、 工 业 光 纤 等 。 光 通信 中 主要 用 石英 光纤 ， 以 后 所 说 
的 光纤 也 主要 是 指 石 英 光 纤 。 


(5) 按 光 纤 的 套 塑 层 分 类 


按 光 纤 的 仅 塑 层 可 分 为 紧 套 光纤 和 松 套 光 纤 两 类 。 紧 套 光 纤 中 光 
纤 被 套 管 紧 紧 地 和 范 住 ， 不 能 在 其 中 松动 ， 它 与 塑料 倒 层 是 一 个 整体 结 
构 。 而 松 套 光 纤 可 在 套 管 层 中 松动 。 套 管内 填充 油 襄 ， 以 防水 渗入 。 
奉 一 根 管内 人 台 有 多 根 光 纤 ， 则 称 为 松 套 光 纤 束 。 紧 套 光 纤 和 松 套 交 纤 
外 观 及 截面 结构 分 别 如 图 4-67 所 示 。 
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a) 紧 套 光纤 b) 松 套 光 纤 


图 4-67 紧 套 光纤 和 松 套 光纤 外 观 及 截面 结构 


4.6.2 ”光纤 结构 及 主要 附件 


为 了 使 大 家 对 光纤 结构 有 个 初步 了 解 ， 本 市 介绍 一 些 肖 见 类 型 的 
光纤 结构 。 实 际 上 光纤 类 型 相当 复杂 ， 各 种 不 同类 型 的 光纤 结构 也 是 
多 种 多 样 的 。 


图 4-68 所 示 的 分 别 为 单 必 光 纤 和 多 心 光 纤 截 面 结构 示意 。 在 光纤 结 
构 中 我 们 还 要 了 解 的 一 点 束 是 光纤 的 接口 类 型 ， 也 束 是 光纤 连接 絮 类 
型 。 光 纤 连 接 器 常见 的 有 ST、SC、LC、FC 等 几 类 ， 下 面 分 别 了 予以 介 


绍 . 


PVC 外 套 
绝缘 防火 层 
防水 凝 胶 
多 必 光 纤 
中 心 支柱 


PVC 外 套 


a) 单 光 心 光缆 结构 图 b) 多 光 心 光缆 结构 图 


图 4-68 单 /多 模 光纤 结构 


1. 光 纤 模 块 


说 到 光纤 连接 器 就 自然 想到 常见 的 两 种 光纤 模块 : GBIC (Giga 
Bitrate Interface Converter， 和 于 兆 位 接口 转换 器 ) 和 SFP (Small Form- 
factor Pluggable， 小 型 可 拔 插件 ) ， 如 图 4-69 所 示 。GBIC 是 将 千 兆 位 电 
言 号 转换 为 光 信号 的 接口 器 件 。 其 插入 到 千 光 位 以 太 网 端口 / 揪 槽 内 ， 
负责 将 端口 与 光纤 网 络 连接 在 一 起 ， 文 持 热 播 拔 ， 并 在 同一 个 模块 上 
支持 IEEE 802.3z 标 准 的 1000BaseSX、1000BaseLX/LH 或 1000BaseZX 接 
口 混用 。SFP 可 以 简单 地 理解 为 GBIC 的 升级 版 本 ， 体 积 比 GBIC 模 块 减 
少 一 半 ， 可 以 在 相同 的 面板 上 配置 多 出 一 倍 以 上 的 端口 数量 ， 其 他 功 
能 基本 和 GBIC 一 致 。 目 前 更 多 的 是 采用 SFP 模 块 ， 因 为 它 体积 小 ， 同 
体积 下 可 以 扩展 更 多 的 端口 数 。 


a) GBIC 


图 4-69 ”GBIC 和 SFP 光 纤 模 块 


从 图 4-69 中 可 以 看 出 ， 无 论 是 GBIC 还 是 SFP 模 块 ， 它 都 会 有 两 个 
端口 (或 者 偶数 个 端口 ， 其 原因 是 光纤 默认 是 不 支持 全 双 工 模式 
的 ， 它 需要 一 条 光纤 用 于 发 送 数据 ， 一 条 光纤 用 于 接收 数据 。 不 过 ， 
目前 高 档 一 些 的 设备 都 是 提供 图 4-70 所 示 的 SFP 模 块 ， 上 面 只 有 一 个 端 


口 ， 接 一 条 光纤 。 原 因 就 是 它 采 用 了 WDM ( 波 分 复 用 ) 技术 ， 使 得 在 
一 条 光纤 中 可 以 划分 成 两 个 信道 ， 进 行 全 双 工 传输 (模块 上 那个 双向 
箭头 就 表示 可 以 双向 传输 的 ) 。 


图 4-70 单 端 口 的 全 双 工 SFP 模 块 


前 面 介 绍 的 GBIC 和 SFP 是 两 个 千 兆 以 太 网 模块 ， 对 于 现在 万 兆 
(10G) 以 太 网 来 说 ， 有 了 新 的 光纤 模块 XFP 〈X 就 代表 “十 ”的 意 
思 ) ， 如 图 4-71 所 示 。XFP 模 块 一 般 都 支持 WDM (通常 是 DWDM， 即 
密集 波 分 复 用 ) 技术 ， 所 以 通常 一 个 模块 就 接 一 条 光纤 ， 即 可 实现 全 


双 工 传输 。 


图 4-71 XFP 光 纤 模 块 


光纤 连接 器 就 是 接 入 光 模 块 的 光纤 接头 ， 其 有 好 多 种 ， 且 相互 之 
间 不 可 以 互 用 。 而 且 ，GBIC 和 SFP 模 块 的 光纤 连接 器 是 不 同 的 : SFP 模 
块 接 LC 连接 器 ，GBIC 接 SC 连接 器 。 除 了 LC、SC 连 接 器 外 ， 我 们 还 经 
常 听 到 另外 两 种 光纤 连接 器 一 一 ST 和 FC 连接 器 ， 下 面 分 别 予以 介绍 。 
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3.ST 连 接 器 


ST 连 接 器 常用 于 光纤 配 线 架 ， 光 纤 世 外露， 且 接 口 呈 圆 形 ， 播 针 
的 端面 多 采用 PC 型 或 APC 型 研磨 方式 ， 紧 固 方式 为 螺钉 扣 ， 如 图 4-72 
所 示 。 对 于 10Base 一 F 光 纤 以 太 网 标准 连接 ， 连 接 髓 通常 是 ST 类 型 的 。 


图 本 72” ST 连接 器 


前 面 说 的 研磨 方式 是 指 光 纤 头 的 形状 ，PC (Physical Contact， 物 
理 接 触 ) 征 指 纤 必 和 光纤 网 络 接口 的 骨 套 是 平面 型 的 紧密 接触 ， 而 APC 
(Angled Physical Contact， 呈 一 定 角 度 的 物理 接触 ) 是 指 纤 芯 和 光纤 
网 络 接口 的 舱 套 是 有 一 定 角度 的 紧密 接触 。 由 于 APC 的 结构 与 PC 完全 
不 同 ， 如 果 用 光纤 法 兰 盘 〈 也 就 是 光纤 适配器 ， 是 光纤 活动 连接 器 对 
的 连接 部 件 ， 图 4-73 列 出 了 四 种 主要 的 适配器 ) 连接 这 两 种 连接 器 ， 会 
损坏 连接 器 的 光纤 端面 。 连 接 APC 到 PC 的 办 法 : 通过 PC 到 APC 转 换 的 
光纤 跳 线 来 实现 。ST 一 APC 连 接 器 通常 是 绿色 的 (黄色 的 光纤 只 是 单 


沽 


模 光 纤 ) ， 而 且 人 有 眼 避 ® 能 看 到 光纤 端面 的 倾斜 (也 就 是 有 一 定 角 


不 是 平面 的 ) 。 
ST 
图 4-73 四 种 主要 的 光纤 适配器 


FC 


SC 


4.SC 连 接 器 


SC 连接 器 是 由 日 本 NTT 公 司 开 发 的 ， 是 连接 GBIC 光 纤 模 块 的 连接 
器 ， 对 于 100Base 一 FX 来 说 ， 连 接 器 大 部 分 情况 下 为 SC 类 型 的 。SC 连 
接 器 的 外 壳 呈 矩形 ， 纤 芯 在 接头 里 面 (ST 连接 器 的 纤 芯 露 在 外 面 ) ， 
其 插 针 的 端面 多 采用 PC 型 或 APC 型 研磨 方式 (SC 一 APC 连 接 器 通常 是 
绿色 的 ，SC 一 PC 连接 通常 是 蓝 色 或 灰色 的 ) ， 紧 固 方式 采用 插 拔 销 问 
式 ， 无 须 旋 转 ， 如 图 4-74 所 示 。 此 类 连接 器 价格 低廉 ， 插 拔 操 作 方 便 ， 
介入 损耗 波动 小 ， 抗 压强 度 较 高 ， 安 装 密度 高 。 


图 4-74 SC 连接 器 


SC 连接 絮 在 路 由 器 、 交 换 机 上 用 得 最 多 。 
5.FC 连 接 器 


FC 
司 人 研制， 
75 所 示 。 


(Ferrule Connector， 人 金属 连接 器 ) 连接 器 最 早 是 由 日 本 NTT 公 
其 外 部 是 金属 套 (连接 更 加 紧 ) ， 紧 固 方式 为 螺钉 扣 ， 如 图 4- 
最 早 的 FC 连接 器 采用 陶 次 插 针 的 对 接 端面 是 平面 接触 方式 ， 
后 来 采用 对 接 端 面 呈 球 面 的 插 针 ， 但 外 部 结构 没有 改变 。 


图 4-75 FC 连接 器 


FC 连接 器 一 般 用 于 连接 配 线 架 。 
6.LC 连 接 器 


LC 连接 器 是 由 著名 的 Bell (贝尔 ) 研究 所 研究 开发 出 来 的 ， 是 连 
接 SFP 模 块 的 连接 右 ， 采 用 操作 方便 的 模块 化 插 孔 (RDJ) 门 锁 机 理 制 成 ， 
如 图 4-76 所 示 。 该 连接 右 所 采用 的 插 针 和 套 简 的 尺寸 是 普通 SC、FC 等 
所 用 尺寸 的 一 半 ， 提 高 了 光 配 线 架 中 光纤 连接 名 的 密度 。 


图 4-76 LC 连接 器 


LC 连接 器 在 路 由 紫 上 用 得 比较 多 。 


光纤 两 端的 连接 器 可 以 一 样 (用 于 连接 相同 类 型 的 光纤 网 络 接 
口 ) ， 也 可 以 不 同 (用 于 连接 不 同类 型 的 网 络 接口 ) ， 图 4-77~ 图 4-81 
征 几 种 利 见 的 市 有 相同 或 不 同 连接 弟 的 光纤 。 


图 4-77 LC-LC 光 纤 


图 4-79 SC-LC 光 纤 
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图 4-80 STFC 光纤 


4.6.3” 非 导 癌 介质 


“ 非 导 癌 介 质 ” 束 古 用 于 无 线 传输 的 各 种 电磁 波 ， 在 数据 通信 中 主 
要 应 用 于 短波 无 线 传输 、 地 面 微波 接力 通信 、 地 球 卫 星 通 信 、WLAN 
(无 线 局 域 网 ) 等 (其实 像 蓝 牙 这 类 无 线 通 信也 是 采用 非 导 向 介质 
的 ) 。 下 面 仅 简单 介绍 短波 无 线 传输 、 地 面 微波 接力 通信 、 地 球 卫星 
通信 这 三 种 ，WLAN 在 本 书 第 6 章 有 专门 的 介绍 ， 在 此 不 表 移 述 。 


1. 短 波 无 线 传输 


短波 无 线 传 输 的 实现 主要 靠 电 离 层 的 反射 。 短 波 的 信号 频率 低 于 
100MHz， 但 电离 层 的 不 稳定 所 产生 的 衰落 现象 和 电离 层 反 射 所 产生 的 
多 径 效 应 ， 使 得 短波 信道 的 通信 质量 较 差 。 最 典型 的 短波 无 线 传 输 应 
用 束 是 无 线 局 域 网 连接 和 手机 通信 。 在 这 种 通信 中 ， 固 定 终端 后 ( 基 
站 ) 和 终端 之 间 是 通过 无 线 链 路 连接 的 。 


2. 地 面 微波 接力 通信 


地 面 微 波 接力 通信 在 数据 通信 中 占 重要 地 位 。 微 波 的 频率 范围 为 
300MHz~300GHz， 在 空中 主要 是 直线 传播 ， 可 经 电离 反射 到 很 远 的 地 
方 。 同 时 ， 由 于 微波 在 空中 是 直线 传播 ， 而 地 球 表面 是 个 曲面 ， 因 此 
传输 距离 受到 限制 。 


地 面 微波 接力 通信 是 在 两 个 地 面 站 之 间 进 行 数据 传送 ， 距 离 一 般 
在 (50~100) km 之 间 ， 如 图 4-82 所 示 。 微 波 接力 通信 可 传输 电话 、 电 


报 、 图 像 、 数 据 等 信息 。 
地 面 微波 


Mi- 和 


地 球 表面 


图 4-82 地 面 微波 搂 力 通信 


很 明显 ， 卫 星 通信 就 是 借助 于 地 球 卫星 进行 的 数据 通信 ， 如 图 4-83 


所 示 。 卫 星 通信 通常 采用 C 波 段 的 〈4~6) GHz 频段 ， 上 行 链 路 为 
(5.925~6.425) GHz， 下 行 链 路 为 〈3.7~4.2) GHz。 如 果 采 用 KU 波段 


的 (12~14) GHz 频段 ， 则 上 行 链 路 为 (14~14.5) GHz， 下 行 链 路 为 


(11.7~12.2) GHz 。 


.< 


ES 


4 地 球 通信 卫星 


图 4-83 卫星 通信 示意 图 


卫星 通信 的 特点 : 频带 宽 、 通 信 容 量 大 、 通 信 距 离 远 ， 且 通信 费 
用 与 通信 距离 无 天， 具有 较 大 的 传播 时 延 ; 安全 保密 性 较 差 ， 造 价 
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4.7 信 记 多 路 复 用 技术 


在 本 章 前 面 已 说 到 ， 计 算 机 网 络 中 的 数据 是 在 物理 链 路 的 各 个 信 
道中 传输 的 〈 通 向 在 一 条 物理 链 路 上 会 有 多 条 信道 的 ) 。 默 认 情 况 
下 ， 一 条 信道 只 传输 一 路 信号 ， 这 融 有 可 能 造成 信道 市 视 软 源 的 当 
费 ， 如 在 某 路 信和 号 传输 所 需 的 带宽 严重 低 于 信道 带宽 时 。 就 像 一 条 大 
马路 上 的 某 条 和 车道 ， 因 为 该 车 道 在 划分 时 束 考 虑 了 大 货车 通过 时 对 车 
道 宽度 的 要 求 ， 所 以 车 道 比较 宽 。 而 事实 上 在 这 条 马路 上 通过 的 绝 大 
多 数 古 小 汽车 ， 很 少 有 大 货车 在 这 条 车 道中 通过 。 如 琳 仍 按 交 通 规 
则 ， 一 条 车 道 只 允许 一 路 汽车 通过 的 话 ， 显 然 就 会 造成 这 条 大 车 道 利 
用 率 的 下 降 。 为 了 解决 这 个 问题 ， 交 警 可 以 在 这 条 大 芋 道 上 再 划分 成 
两 条 小 车 道 ， 在 没有 大 货车 通过 时 允许 两 部 小 汽车 在 这 两 条 小 车 道上 
同时 通过 ， 这 样 可 大 大 提高 这 条 大 车 道 的 利用 率 。 


对 于 计算 机 网 络 中 的 数据 传输 也 一 样 ， 我 们 可 以 把 一 条 高 带宽 的 
言 道 划 分 成 多 条 小 带宽 的 子 信 道 〈 注 意 ， 子 信道 是 逻辑 意义 上 的 ， 称 
为 逻辑 信道 ) ， 这 样 就 可 以 在 一 条 信道 上 同时 进行 多 路 低 带 宽 需 求 的 
言 吕 传输， 可 大 大 提高 原来 这 条 信道 的 利用 率 。 这 就 是 我 们 这 里 所 讲 
的 “信道 复 用 ”(Channel Multiplexing) 技术 。 这 里 * 复 用 ”就 是 “共用 ”， 
或 者 “共享 ”的 意思 ， 也 就 是 多 路 信号 共用 原来 这 一 条 信道 进行 数据 传 
输 。 各 种 信道 复 用 技术 都 在 发 六 端 有 对 应 的 “ 复 用 硕 ”"， 而 在 接收 病 叉 


有 对 应 的 “分 用 右 ”。“ 分 用 器 ”的 用 途 丈 是 把 原来 在 同一 信道 中 传输 的 各 
子 信道 中 多 路 信号 分 享 出 来 。 
根据 不 同 的 信号 和 传输 介质 类 型 ， 可 以 采用 不 同 的 信道 复 用 技 

术 ， 这 些 信道 复 用 技术 主要 有 : 频 分 复 用 (Frequency Division 


Moultiplexing，FDM) 、 时 分 复 用 (Time Division Multiplexing ， 
、 波 分 复 用 (Wave Division Multiplexing，WDM) 和 码 分 复 用 


TDM) 
(Code Division Multiplexing，CDM) 。 本 节 将 具体 介绍 


频 分 复 用 及 其 原理 
频 分 复 用 (FDM) 是 按照 信道 频带 宽度 进行 信道 复 用 的 方式 (也 
是 一 种 调制 技术 ) ， 就 是 把 一 条 高 带宽 的 信道 按照 一 定 的 频带 宽度 划 
分 成 若干 个 低 带 宽 的 子 频带 〈 或 称 子 信道 ， 如 图 4-84 所 示 ， 每 个 子 频带 
的 宽度 一 般 是 一 样 的 ， 但 也 可 以 不 一 样 ) ， 以 实现 同一 时 刻 通 过 不 同 
页 率 的 载波 调制 技术 在 信道 中 传输 多 路 基带 信号 的 目的 。 如 有 一 个 频 
带宽 度 (也 就 是 信道 带宽 ) 为 (1~10) MHz 的 信道 ， 现 在 如 果 要 划分 
则 可 划分 为 (1~2.5) MHz 、 (2.52~5.0) MHz、 


(7.52~10.0) MHz 。 


道 ， 
由 


成 4 个 于 信道 ， 
(5.02~7.5) MHz 、 


子 信道 4 (频带 4 ) 


二 原 信道 
子 信道 2 ( 频带 2 ) 
子 信 道 1 (频带 1 ) 

时 间 (2) 


图 4-84 FDM 信 道 复 用 原理 


1.FDM 基 本 原理 


在 FDM 系 统 中 ， 信 道 的 可 用 频 市 彼 分 成 大 干 个 互 不 交 谷 的 频 
从 多 条 线路 输入 的 多 路 基 市 信 与 通过 FDM 复 用 右 分 别 用 一 个 不 同 频 市 
的 载波 进行 调制 ， 然 后 在 同一 个 信道 中 的 不 同 子 信道 中 传输 ， 但 是 每 
路 已 调 信和 号 只 占用 原 信道 中 一 部 分 频带 《也 就 是 对 应 子 信道 中 的 频 
带 ， 如 图 4-85 所 示 ) ， 在 接收 端 再 通过 FDM 分 用 器 中 的 带 通 滤波 器 将 
它们 分 别 滤 出 来 ， 最 后 通过 各 线路 的 解 调 逆 置 解 调 接收 即 可 。 


潜 


复 用 融 


图 4-85 FDM 复 用 示例 


这 里 就 涉及 到 一 个 信号 工作 频带 的 搬移 问题 ， 大 不 搬移 在 同一 信 
道中 传输 的 多 路 信号 工作 频带 就 可 能 重 村， 者 重要 了 ， 目 然 就 达 不 到 
信道 复 用 的 目的 了 。 这 个 频带 搬移 工作 就 是 由 FDM 复 用 器 来 完成 的 。 
它 可 以 把 进入 同一 信道 的 多 路 信号 的 工作 频 市 依次 搬移 到 对 应 子 信道 
的 频带 中 (参见 图 4-85) ， 这 样 多 路 信号 就 可 以 在 同一 个 信道 中 互 不 干 
扰 地 进行 传输 了 。 束 像 一 个 合唱 中 ， 要 使 每 部 分 人 的 声音 都 能 很 好 地 
被 分 辨 出 来 ， 必 须要 使 一 部 分 人 采用 低音 歌唱 ， 一 部 分 人 采用 中 音 歌 
唱 ， 还 有 一 部 分 人 采用 高 音 歌唱 。 如 果 大 家 都 采用 同一 个 音调 歌唱 ， 
就 很 难 区 分 每 部 分 人 唱歌 的 声音 。 但 在 FDM 中 ， 为 了 防止 相 邻 子 信道 
中 传输 信号 的 相互 干扰 ， 不 仅 各 子 信道 之 间 的 载波 频 市 是 完全 分 隔 、 
不 重 登 的， 而且 相 邻 子 信道 中 的 频 市 之 间 最 好 要 有 一 定 间 际 ， 所 以 
FDM 对 频带 的 利用 率 也 十 相对 较 低 的 ， 当 复 用 的 路 数 不 古 很 多 时 ， 可 
以 考虑 选择 这 种 信道 复 用 方式 。 图 4-86 所 示 是 一 个 FDM 的 应 用 示例 ， 
三 台 主 机 通过 一 条 线路 进行 数据 传输 。 


图 4-86 FDM 示 例 


FDM 系 统 的 优点 是 信道 复 用 率 高 ， 实 现 简单 ， 是 目前 模拟 通信 中 
常 采 用 的 一 种 复 用 方式 。 但 同时 FDM 又 存在 一 些 问题 ， 主 要 表现 为 各 
路 信号 之 间 存 在 相互 干扰 ， 即 串扰 。 引 起 串扰 的 主要 原因 是 滤波 郁 特 
性 不 够 理想 和 信道 中 的 非 线性 特性 《就 是 有 突变 ) 造成 的 已 调 信号 频 
谱 的 展 宽 〈 也 束 是 一 个 子 信 道中 的 信和 号 频率 可 能 渗透 到 了 另 一 子 信道 
中 ) 。 调 制 过 程 中 非 线性 特性 所 造成 的 串扰 可 以 一 部 分 一 部 分 地 由 发 
送 市 通 滤 波 郁 消除 ， 但 信道 传输 中 非 线性 所 造成 的 串扰 则 无 法 消 除 ， 
因而 在 FDM 系 统 中 对 系统 线性 的 要 求 很 高 另外， 在 调制 过 程 中 合理 
地 选择 载波 频率 ， 并 在 各 路 已 调 信 号 频谱 之 间 留 有 一 定 的 保护 间隔 ， 
也 是 减 小 串扰 的 有 效 措施 。 


FDM 最 典型 的 应 用 就 古 模 拟 / 数 子 电视 、 厂 播 系统 ， 电 台 、 电 视 台 
使 用 某 个 固定 特殊 的 频 市 或 频道 来 做 为 茶 套 广播 、 电 视 的 传输 。 以 前 
的 模拟 电话 交换 系统 也 是 采用 FDM 复 用 方式 的 ，12 路 语音 信道 被 调制 
到 载波 上 各 自 占据 4kHz 带 宽 ， 可 实现 在 单个 物理 电路 上 传输 若干 条 语 
首 信 道 通 信 。 不 过 ， 现 在 的 数字 电话 系统 基本 上 已 被 下 市 将 要 介绍 的 
TDM (时 分 复 用 ) 复 用 方式 所 取代 了 。 


2.0FDM 


频 分 复 用 技术 除 传统 的 FDM 外 ， 还 有 一 种 OFDM (Orthogonal 
Frequency Division Multiplexing， 正 交 频 分 复 用 ) 。 它 是 一 种 多 载波 调 
制 (QMulti-Carrier Modulation,MCM) 技术 ， 可 将 信道 分 成 若干 正 交 子 


信道 ， 然 后 将 高 速 数据 信号 转换 成 并 行 的 低速 子 数据 流 ， 调 制 到 在 每 
个 子 信道 上 进行 传输 。 


所 谓 多 载波 调制 是 指 发 送 并 将 数据 流 分 解 为 耕 干 个 于 数据 流 ， 从 
而 使 子 数据 流 具 有 低 得 多 的 传输 比特 率 ， 再 利用 这 些 数 据 分 别 去 调制 
奉 干 个 载波， 然后 同时 发 送出 去 的 调制 技术 ， 其 传输 过 程 中 采用 的 是 
并 行 化 传输 技术 。 与 多 载波 调制 对 应 的 就 是 单 载波 调制 (Single-Carrier 
ModulationSCM)， 它 是 指 将 需要 传输 的 数据 流 调制 到 单个 载波 上 进行 
传送 的 调制 技术 。 如 本 章 前 面 介 绍 的 ASK、FSK、PSK 调 制 技术 都 属于 
单 载波 调制 技术 。 


“ 正 交 ”十 指 各 个 载波 的 信号 频谱 是 正 交 的 ， 也 束 古 各 载波 的 信号 
频谱 可 以 有 交 义 ， 但 不 能 重合 ， 可 以 通过 某 种 技术 实现 完全 的 分 开 。 
由 于 OFDM 使 用 了 无 干扰 的 正 交 多 载波 调制 技术 ， 不 仅 提 高 了 多 路 子 
言 道 信 号 的 调制 效率 ， 而 且 由 于 各 载波 间 可 以 交叉 ， 无 须 保护 频 市 ， 
这 样 使 得 信道 中 可 用 频谱 的 使 用 效率 更 高 ， 比 FDM 系 统 中 所 要 求 的 信 
道 市 宽 要 小 得 多 。 夯 外 ，OFDM 技 术 可 动态 分 配子 信道 中 的 数据 ， 为 
获得 最 大 的 数据 吞吐 量 ， 多 载波 调制 锅 可 以 智能 地 分 配 更 多 的 数据 到 
噪声 小 的 子 信道 上 。 


目前 OFDM 技 术 已 被 广泛 应 用 于 广播 式 的 音频 和 视频 领域 以 及 民 
用 通信 系统 中 ， 主 要 的 应 用 包括 ADSL、DVB (数字 视频 广播 ) 、 


HDTV (高 清晰 度 电 视 ) 、WLAN (无 线 局 域 网 ) 和 第 四 代 (4G) 移 


动 通信 系统 等 。 


4.7.2 ”时 分 复 用 及 其 原理 


上 市 介绍 的 频 分 复 用 (FDM) 技术 是 出 于 单一 数据 传输 过 程 中 可 
能 占用 不 了 整 条 信道 完整 带宽 ， 当 费 了 信道 市 宽 资 源 的 考虑 的 ， 这 种 
技术 把 信道 珊 宽 划分 成 多 个 小 带宽 的 子 信道 ， 把 多 路 信和 号 的 发 送 分 别 
搬移 到 对 应 子 信道 上 ， 以 实现 信道 带 视 的 更 高 利用 率 ; 而 这 里 的 时 分 
复 用 (TDM) 则 是 出 于 单 用 户 数据 传输 过 程 中 不 可 能 总 有 数据 传输 ， 
通信 过 程 中 肯定 会 存在 无 数据 传输 的 空 几 时 段 《如 用 户 在 输入 数据 的 
时 候 ， 或 者 用 户 在 查看 数据 ， 或 网 上 信息 的 时 候 等 ) 的 考虑 的 ， 该 技 
术 把 整个 数据 通信 过 程 划分 成 一 个 个 小 的 时 间 段 ( 称 之 为 “< 时间 
片 ") ， 在 这 些 时 间 记 中 又 划分 成 多 个 更 小 的 时 间 间 际 (简称 为 “时 
际 ”) ， 每 个 时 了 可 以 用 于 一 个 用 户 信 号 的 传输 ， 这 样 下 可 以 使 得 每 一 
个 时 间 搬 中 一 般 总 会 有 一 个 或 多 个 时 隙 中 有 信和 号 在 里 面 传输 (因为 一 
般 不 太 可 能 多 路 信号 同时 没有 数据 传输 ) ， 也 可 以 实现 提高 信道 利用 
率 的 目的 。 


如 图 4-87 所 示 的 是 一 个 TDM 示 例 ， 其 复 用 右 先 把 整个 数据 传输 过 
程 划 分 成 一 个 个 小 的 时 间 片 ， 然 后 在 这 些 时 间 片 中 义 划 分 了 四 个 时 
际 ， 分 别 用 于 传输 三 路 信号 (相当 于 三 个 用 户 , 假设 为 A、B、C) 。 


时 间 分 片 1 时 间 分 片 2 


< = 
a 和 
3 所 一 一 一 时 际 号 


5 < 一 时 际 
c [ol fp2] ~ C < 一 信号 代码 


图 4-87 TDM 信 道 复 用 示意 图 


假设 在 某 一 时 间 前 ，A 和 C 路 信号 发 送 了 2 个 数据 帧 (D1 和 D2) ， 
而 B 路 信号 只 发 送 了 一 个 数据 帧 D1， 则 经 过 时 分 复 用 器 复 用 后 ， 这 段 
时 间 前 发 送 的 5 个 数据 帧 分 别 放 在 两 个 时 间 片 中 ， 每 个 时 间 户 划分 了 可 
供 三 路 信和 号 同时 传输 的 三 个 时 阶 。 此 时 我 们 发 现在 第 一 个 时 际 中 ，A 、 
B、C 三 路 信号 都 有 数据 帆 D1 在 传输 ， 而 在 时 间 片 2 中 ，A 和 C 路 信号 都 
在 它们 各 目的 时 隙 中 有 数据 D2 传 输 ， 而 B 路 信号 此 时 没有 数据 传输 。 
在 接收 端 通过 分 复 用 器 即 可 以 还 原 各 路 信和 号。 


时 分 多 路 复 用 建立 在 采样 定理 基础 上 ， 因 为 采样 定理 使 连续 的 基 
带 信号 变 成 在 时 间 上 离散 的 采样 脉冲 ， 这 样 ， 当 采样 脉冲 占据 较 短 时 
间 时 ， 在 采样 脉冲 之 间 惑 留 出 了 时 间 空 除 〈 见 图 4-88) 。 利 用 这 种 空 际 
便 可 以 传输 其 他 信号 的 采样 值 ， 因 此 ， 就 有 可 能 在 一 条 信道 同时 传送 
在 干 个 基 市 信号 。 时 分 多 路 复 用 以 时 间作 为 信号 分 割 的 参量 ， 故 必须 
使 各 路 信号 在 时 间 轴 上 互 不 重要 。 由 于 每 路 数据 总 是 使 用 每 个 时 间 片 
的 固定 时 除 ， 所 以 这 种 时 分 复 用 又 称 同 步 时 分 复 用 。 


图 4-88 TDM 示 例 


时 分 复 用 的 典型 例子 : PCM (Pulse Code Modulation ， 脉 码 调制 ) 
言 号 的 传输 ， 把 多 个 话 路 的 PCM 话 音 数 据 用 TDM 的 方法 装 成 帧 〈 帧 中 
还 包括 了 帧 同步 信息 和 信 令 信息 ) ， 每 帧 在 一 个 时 间 片 内 发 送 ， 每 个 
时 隙 承载 一 路 PCM 信 号 。 


通过 对 以 上 原理 的 解析 可 以 看 出 ， 尽 管 TDM 通 过 划分 小 的 时 隙 可 
以 提高 信道 的 利用 率 ， 但 还 是 会 存在 一 些 不 彻底 的 问题 。 如 在 图 4-87 
中 ， 在 第 二 个 时 间 片 中 ， 因 B 路 信号 此 时 没有 数据 发 送 ， 所 以 该 时 际 仍 
处 于 空间 状态 ， 即 使 其 他 路 信号 的 传输 很 性 ， 也 不 能 占用 该 时 际 进行 
数据 传输 。 所 以 才 有 了 一 种 改进 型 的 TDM， 那 就 是 STDM (Statistical 


Time Division Multiplexing， 统 计时 分 复 用 ) 。 


STDM 是 一 种 可 动态 分 配 时 际 〈 也 就 是 不 为 所 有 用 户 分 配 固定 的 时 
际 ) 的 TDM 。 它 可 以 使 用 按 需 分 配 的 技术 ， 即 根据 用 户 需求 动态 分 配 
时 际 ， 以 避免 传 统 TDM 中 出 现 空 几 时 际 的 现象 ， 因 为 STDM 复 用 器 中 
的 时 际 仅 为 有 数据 传输 的 用 户 分 配 时 际 。 同 样 古 因为 不 为 每 个 用 户 在 
每 个 时 间 户 上 分 配 固定 的 时 除 ， 所 以 用 户 线路 的 时 际 在 各 时 间 片 中 不 
是 周期 性 出 现 的 ， 所 以 STDM 又 称 异 步 时 分 复 用 。 


与 传统 TDM 一 样 ，STDM 也 可 与 n 条 低速 输入 用 户 线路 相连 。 但 由 
于 每 条 输入 线路 并 非 一 直 有 数据 和 输入， 因此 STDM 时 聊 效 k 可 小 于 用 户 
线路 数 n。 这 使 得 复 用 信道 上 的 市 宽 低 于 各 个 输入 线路 市 宽 之 和 ， 或 者 
说 对 于 同样 带宽 的 复 用 信道 ，STDM 可 以 复 接 更 多 的 用 户 线路 ， 即 提高 
了 信道 的 利用 率 。 


4.7.3” 波 分 复 用 及 其 原理 


波 分 复 用 (WDM) 是 光 信 号 中 的 频 分 复 用 技术 (前 面 介 绍 的 FDM 
征 针 对 电信 和 号 的 ) ， 又 称 光 波 分 复 用 ， 有 是 在 单条 光纤 上 同时 发 送 多 束 
不 同 波长 激光 的 技术 。 因 为 光波 信号 的 频率 一 般 非 常 高 ， 不 便于 表 
示 ， 而 波长 相对 更 便于 表示 ， 所 以 在 光 信号 复 用 中 采用 了 流 分 复 用 这 
个 词 。 其 实 它 与 频 分 复 用 是 一 个 意思 的 ， 因 为 不 同 波长 的 光波 对 应 的 
工作 频率 也 不 一 样 。 


试想 一 下 ， 单 独 拉 一 条 光纤 的 成 本 远 比 单独 拉 一 条 双 绞 线 高 ， 如 
琳 在 一 条 光纤 中 只 传输 一 路 信和 号， 肯定 是 不 合算 的 。 再 加 上 ， 不 同 光 
纤 的 波长 并 不 一 样 ， 绝 大 多 数 是 不 能 完全 占用 整 条 光纤 的 市 宽 。 在 以 
前 不 采用 WDM 技 术 的 光纤 连接 中 ， 收 、 发 要 用 两 条 光纤 ， 而 现在 新 型 
的 光纤 连接 中 通常 都 广 持 WDM， 只 和 需 接 一 条 光纤 就 可 实现 收 、 发 两 路 
通信 同时 双 工 工作 了 。 


WDM 走 将 两 种 或 多 种 不 同 波长 的 光 载 波 信和 号 在 发 送 端 经 复 用 骨 
( 义 称 合 波 器 ) 汇合 在 一 起 ， 并 耦合 到 光线 路 的 同一 根 光 纤 中 进行 伟 
输 的 技术 。 在 接收 端 ， 经 分 复 用 器 ( 义 称 分 波 器 或 去 复 用 器 ) 将 各 种 
波长 的 光 载 波 分 离 ， 然 后 由 交接 收 机 做 进一步 处 理 以 恢复 原 信 号 。 
WDM 的 信道 复 用 原理 殉 是 把 一 个 光纤 信道 中 的 整个 波长 市 宽 划 分 为 右 
干 个 小 波长 范围 ， 每 路 光 载 波 信号 占用 一 个 波长 泡 围 来 进行 传输 。 这 


样 一 来 ， 原 来 在 一 根 光 纤 上 只 能 传送 一 个 光 载 波 的 单一 信道 变 为 可 传 
送 多 个 不 同 波长 光 载 波 的 于 信道 ， 从 而 使 得 光纤 的 传输 能 力 成 倍增 

加 。 如 图 4-89 所 示 的 是 三 路 光纤 (A、B、C) 中 的 光 载 波 (假设 各 目 
的 载波 波长 分 别 为 wy 、w 和 ws ) 通过 合 波 器 后 在 一 条 光纤 中 传输 的 
示例 ， 复 用 后 各 路 光 载 波 信 号 的 波长 带宽 分 别 为 wa、ws 和 we (对 应 


小 于 wj AN Wo5 AN W3 ) O 


图 4-89 WDM 示 意图 


波 分 复 用 一 般 将 波长 分 割 复 用 器 和 人 解 复 用 器 (又 称 合 波 /分 波 器 ) 
分 别 置 于 光纤 两 闻 ， 实 现 不 同 光波 的 粳 合 与 分 离 。 这 两 个 器 件 的 工作 
原理 是 相同 的 。 波 分 复 用 器 的 主要 类 型 有 炊 融 拉 锥 型 、 介 质 膜 型 、 光 
栅 型 和 平面 型 四 种 。 


波 分 复 用 的 技术 符 点 与 优势 如 下 : 


(1) 灵活 增加 光纤 传输 容量 


流 分 复 用 技术 可 充分 利用 光纤 的 低 损 耗 波 段 ， 增 加 光纤 的 传输 容 
量 ， 使 一 根 光纤 传送 信息 的 物理 限度 增加 一 倍 至 数 倍 。 对 已 建 光 纤 系 


统 ， 尤 其 早期 铺设 的 忆 数 不 多 的 光缆 ， 只 要 原 系统 有 功率 余 量 ， 可 进 
一 步 增 容 ， 实 现 多 个 单 回 信号 或 双 同 信和 号 的 传送 而 不 用 对 原 系统 做 大 
改动 。 具 有 较 强 的 灵活 性 。 


(2) 同时 传输 多 路 信和 号 


波 分 复 用 技术 使 得 在 同一 根 光 纤 中 传送 2 个 或 多 个 非 同步 信号 成 为 
可 能 ， 有 利于 数字 信号 和 模拟 信和 号 的 兼容 。 而 且 与 数据 速率 和 调制 方 
式 无 天 ， 在 线路 中 间 可 以 灵活 取出 或 加 入 信道 。 


(3) 成 本 低 、 维 护 方便 


采用 波 分 复 用 技术 可 大 量 减 少 光 纤 的 使 用 量 ， 进 而 大 大 降低 建设 
成 本 。 由 于 光纤 数量 少 ， 当 出 现 故障 时 ， 恢 复 起 来 也 迅速 方便 。 


(4) 可 靠 性 高 ， 应 用 广泛 


由 于 系统 中 有 源 设 备 大 幅 减 少 ， 这 样 就 提高 了 系统 的 可 靠 性 。 目 
前 由 于 多 路 载波 的 波 分 复 用 对 光 发 射 机 、 光 接收 机 等 设备 要 求 较 高 ， 
技术 实施 有 一 定 难度 。 同 时 多 纤 必 区 缆 的 应 用 对 于 传统 广播 电视 传输 
业务 未 出 现 特别 紧缺 的 局 面 ， 因 而 WDM 的 实际 应 用 还 不 多 。 但 是 随 着 
有 线 电 视 绿 合 业务 的 开展 ， 网 络 带 视 需求 日 益 增 长 ， 出 于 对 各 类 选择 
性 服务 的 实施 、 网 络 升级 改造 经 济 费用 的 考虑 等 ， 光 波 复 用 的 特点 和 


优势 在 CATV 传 输 系 统 中 逐渐 显现 出 来 ， 表 现 出 广阔 的 应 用 前 景 ， 甚 至 
将 影响 CATV 网 络 的 发 展 格局 。 


4.8 ”物理 层 接口 


ISO 对 OSI 模 型 的 物理 层 所 做 的 定义 为 :在 物理 信道 实体 之 间 合 理 
地 通过 中 间 系 统 ， 为 比特 传输 所 需 的 物理 连接 的 激活 、 保 持 和 去 除 提 
供 机 械 的 、 电 气 的 、 功 能 性 和 规程 性 的 手段 。 比 特 流 传输 可 以 采用 异 
步 传输 ， 也 可 以 采用 同步 传输 完成 。 


另外 ，CCITT 在 X.25 建 议 书 第 一 级 (物理 级 ) 中 也 做 了 类 似 的 定 
义 : 利用 物理 的 、 电 气 的 、 功 能 的 和 规程 的 特性 在 DTE 和 DCE 之 间 实 
现 对 物理 信道 的 建立 、 保 持 和 拆除 功能 。 这 里 的 DTE (Date Terminal 
Equipment) 指 的 是 数据 终端 设备 ， 是 对 属于 用 户 所 有 的 连 网 设备 或 工 
作 站 的 统称 ， 它 们 是 通信 的 信 源 或 信 宿 ， 如 计算 机 、 终 端 等 ，DCE 
(Date Circuit Terminating Equipment 或 Date Communications 
Equipment) ， 指 的 是 数据 电路 终 接 设备 或 数据 通信 设备 ， 是 对 为 用 户 
提供 接 入 点 的 网 络 设备 的 统称 ， 如 自动 呼叫 应 答 设 备 、 调 制 解 调 器 


和 任 。 
可 


4.8.1 串 行 接口 标准 


在 计算 机 网 络 数据 通信 中 ， 有 几 个 接口 标准 是 经 常见 到 和 用 到 
的 ， 那 就 是 通常 所 说 的 RS-232、RS-422 与 RS-485 标 准 。 它 们 都 是 串 行 


数据 接口 标准 ， 最 初 都 是 由 电子 工业 协会 (EIA) 制定 并 发 布 的 。 


RS-232 接 口 (又 称 EIA RS-232) 是 目前 最 常用 的 一 种 串 行 通信 接 
口 。 它 是 在 1970 年 由 美国 电子 工业 协会 (EIA) 联合 贝尔 系统 、 调 制 解 
调 器 厂家 及 计算 机 终端 生产 厂家 共同 制定 的 用 于 串 行 通 信 的 标准 。 它 
的 全 名 是 “数据 终端 设备 (DTE) 和 数据 通信 设备 \DCE) 之 间 串 行 二 
进 制 数据 交换 接口 技术 标准 ”。 该 标准 规定 采用 一 个 25 个 脚 的 DB25 连 接 
器 ， 对 连接 器 的 每 个 引 脚 的 信号 内 容 进行 了 规定 ， 还 对 各 种 信号 的 电 
平 进行 了 规定 。 


RS-422 由 RS-232 发 展 而 来 ， 它 是 为 弥补 RS-232 之 不 足 而 提出 的 。 
为 改进 RS-232 通 信和 距离 短 、 速 率 低 的 缺 操 ，RS-422 定 义 了 一 种 平衡 通 
信 接 口 ， 将 传输 速率 提高 到 10Mbps， 传 输 距 离 延 长 到 4000 英 尺 (速率 
低 于 100kbps 时 ) ， 并 允许 在 一 条 平衡 总 线 上 连接 最 多 10 个 接收 器 。 
RS-422 是 一 种 单机 发 送 、 多 机 接收 的 单 向 、 平 衡 传 输 规范 ， 后 来 被 命 
名 为 TIA/EIA-422A 标 准 。 为 扩展 应 用 范围 ，EIA 义 于 1983 年 在 RS-422 
基础 上 制定 了 RS-485 标 准 ， 增 加 了 多 点 、 双 向 通信 能 力 ， 即 允许 多 个 
发 送 器 连接 到 同一 条 总 线 上 ， 同 时 增加 了 发 送 器 的 驱动 能 力 和 冲突 保 
护 特性 ， 扩 展 了 总 线 共 模范 围 ， 后 命名 为 TIA/EIA-485A 标 准 。 由 于 EIA 
提出 的 建议 标准 都 是 以 “RS” 作 为 前 级 ， 所 以 在 通信 工业 领域 ,仍然 习 
惯 将 上 述 标 准 以 RS 作 前 级 ， 也 就 是 上 面 说 到 的 三 个 串 行 接口 标准 。 


RS-232、RS-422 与 RS-485 标 准 只 对 接口 的 电气 特性 做 出 规定 ， 而 
不 涉及 接 插 件 、 电 缆 或 协议 ， 在 此 基础 上 用 户 可 以 建立 自己 的 高 层 通 
信 协 议 。 因 此 在 视频 界 的 应 用 ， 许 多 厂家 都 建立 了 一 套 高 层 通 信 协 
议 ， 或 公开 或 厂家 独家 使 用 。 


表 4-1 所 示 是 以 上 三 种 串 行 接口 电气 性 能 参数 的 综合 比较 。 


表 4-1 RS-232、RS-422 与 RS-485 串 行 接口 电气 性 能 参数 综合 比较 


-3 一 +3 -1 一 +3 


-7 一 +7 -7 一 +12 


驱动 器 共 模 电压 /V 
接收 器 共 模 电压 /V 


性 能 参数 RS-232 RS-485 
工作 方式 差分 
和 EET 
最 大 传输 电缆 长 度 / 英尺 400 
最 大 传输 速率 /bps 20k 10M 10M 
最 大 驱动 输出 电压 /V -0.25 ~ +6 -7 二 及 
驱动 器 输出 信号 电 平 (负载 最 小 值 )/V +/—1.5 
驱动 器 输出 信号 电 平 〈 空 载 最 大 值 ) /V +/-6 
驱动 器 负载 阻抗 /Q | 3k~7k | | $4 
摆 率 (最 大 值 ) N/A 
接收 器 输入 电压 范围 /V = 
接收 器 输入 门限 +/—200mV 
接收 器 输入 电阻 /Q = 12k 

| | em | 
| | | 


4.8.2 RS-232 串 行 接口 标准 


目前 RS-232 是 PC 机 与 通信 工业 中 应 用 最 广泛 的 一 种 串 行 接口 ， 其 
中 RS (ecommeded standard) 代表 推荐 标准 ，232 是 标识 号 。RS-232 被 
定义 为 一 种 在 低速 率 串 行 通 信 中 增加 通信 距离 的 单 端 标准 。RS-232 采 
取 不 平衡 传输 方式 ， 即 所 谓 单 端 通信 。 一 个 完整 的 RS-232 接 口 有 22 根 
线 ， 采 用 标准 的 25 世 插头 座 (DB-25) 。 除 此 之 处 ， 目 前 广泛 应 用 的 还 
有 一 种 9 心 的 RS-232 接 口 (DB-9) 。 它 们 的 外 观 都 是 D 形 的 ， 不 过 ， 对 
接 的 两 个 接口 又 分 为 针 式 的 公 头 和 和 孔 式 的 母 头 两 种 ，DB-9 的 母 头 和 公 
头 和 DB-25 的 母 头 和 公 头 分 别 如 图 4-90 所 示 。 


Pin 1 Pin 1 Pinl Pnl 
| 9 pin9 Pin25 Pin 25 
DB-9 的 母 头 和 公 头 DB-25 的 母 头 和 公 头 


图 4-90 DB-9%DB-25 的 公 头 和 母 头 


在 RS-232 标 准 中 定义 了 逻辑 一 和 逻辑 零 电 压 级 数 ， 以 及 标准 的 传 
输 速 率 和 连接 器 类 型 。 信 号 大 小 在 +3~+15V 之 间 。RS-232 规 定 接 近 零 
的 电 平 是 无 效 的 ， 逻 辑 一 规定 为 负电 平 ， 有 效 负 电 平 的 信号 状态 称 为 


传 号 (marking) ， 它 的 功能 意义 为 OFF; 逻辑 零 规 定 为 正 电 平 ， 有 效 
正 电 平 的 信号 状态 称 为 空 号 (spacing) ， 它 的 功能 意义 为 ON。 根 据 设 
备 供 电 电 源 的 不 同 ，+5V、+10V、+12V 和 +15V 这 样 的 电 平 都 是 可 能 
的 。 


1 RS-232 连 接 器 


RS-232 标 准 中 规定 的 设备 可 以 分 为 数据 终端 设备 (DTE) 和 数据 
通信 设备 (DCE) 两 类 ， 这 种 分 类 定义 了 用 不 同 的 线路 来 发 送 和 接受 
信和 号。 一 般 来 说 ， 计 算 机 和 终端 设备 用 DTE 连 接 器 ， 调 制 解 调 器 和 打 
印 机 用 DCE 连 接 器 。 


RS-232 标 准 中 指 是 了 20 个 不 同 的 信号 连接 ， 而 RS-232 连 接 絮 是 由 
25 个 D-sub (微型 D 类 ) 引 脚 构成 的 DB-25 连 接 器 。 但 很 多 设备 只 是 用 
了 其 中 的 一 小 部 分 引 脚 ， 出 于 节省 资金 和 空间 的 考虑 ， 不 少 机 器 采用 
较 小 的 连接 器 ， 特 别 是 9 引 脚 的 D-sub 或 者 是 DB-9 型 连接 器 被 广泛 应 用 
于 绝 大 多 数 IBM 的 AT 机 之 后 的 PC 机 和 其 他 许多 设备 上 。 


因为 RS-232 到 目前 为 止 经 历 了 好 多 个 不 同 版 本 ， 最 近 的 版 本 号 为 
E， 它 相对 目前 广泛 应 用 的 C 版 本 来 说 ， 电 气 性 能 改进 了 不 少 ， 也 对 连 
接 强 中 的 25 个 引 脚 进行 了 充分 利用 (只 有 2 个 予以 保留 ) 。 表 4-2 列 出 的 
是 25 心 RS-232E 接 口 的 信号 和 引 脚 分 配 ， 而 表 4-3 所 示 的 则 是 在 PC 机 、 


调制 解 调 器 和 路 由 器 等 网 络 设备 中 使 用 的 9 心 RS-32 接 口 的 信和 号 和 引 脚 


sy 


表 4-2 25 芯 RS-232 接口 的 信号 和 引 脚 分 配 


引 脚 号 说 。 明 
3 RXD ee 接收 数据 
1 请 天 
6 输入 数据 设备 准备 好 
7 公共 端 过 号 地 
: CE 
; -| -| mn 
1 Tr 
1 ET TT 全 
12 DCD 和 载波 检测 
本 和 证 发 
14 TXD 输 L 发 送 数 据 
16 RXD 输入 接收 数据 
( 续 ) 
引 脚 号 缩写 符 信号 方向 说 明 
1 ET 
1 地 加 出 
19 RTS 输出 请 求 发 送 
20 输出 数据 终端 准备 好 
21 输出 远程 回路 控制 
22 CR | 输入 振 铃 指示 器 
23 DSR | ”一 | 数据 装置 准备 好 


3 TREE 


表 4-3 9 芯 RS-232 接口 的 信号 和 引 脚 分 配 


TE 克 
ET 
EE TI 
5 TT 
; | WA | 


在 RS-232C 版 本 中 ，DB-25 的 25 个 引 脚 (4 个 数据 引 脚 、11 个 控制 
言 号 引 脚 、3 个 定时 引 脚 、7 个 备用 和 未 定义 引 脚 ) 实际 上 只 用 了 表 4-2 
中 的 9 个 ， 分 别 是 1、2、3、4、5、6、8、20、22 引 脚 。 它 们 的 作用 分 
别 如 下 : 


(1) 控制 信号 引 脚 (4、5、6、8、20 和 22 引 脚 ) 


口 数据 装置 准备 好 (Data set ready，DSR) : 第 6 脚 ， 有 效 时 
(ON) 状态 ， 表 了 明 接 口 处 于 可 以 使 用 的 状态 。 


口 数据 终端 准备 好 (Data set ready，DTR) : 第 20 脚 ， 有 效 时 
(ON) 状态 ， 表明 数据 终端 可 以 使 用 。 


这 两 个 信号 有 时 连 到 电源 上 ， 一 上 电 就 立即 有 效 。 但 这 两 个 设备 
状态 信号 有 效 ， 只 表示 设备 本 映 可 用 ， 并 不 说 明 通 信和 链 路 可 以 开始 进 
了 通信 人 否 开 始 进 行 通信 要 由 下 面 的 控制 信号 决定 。 


口 请 求 发 送 (Request to send，RTS) : 第 4 脚 ， 用 来 表示 DTE 请 求 
DCE 发 送 数 据 ， 即 当 终 端 要 发 送 数据 时 ， 使 该 信号 有 效 (ON 状态 ) ， 
向 DTE 设 备 请 求 发 送 。 


口 允 许 发 送 (Clearto send，CTS) : 第 5 脚 ， 用 来 表示 DCE 准 备 好 
接收 DTE 发 来 的 数据 ， 是 对 请 求 发 送信 号 RTS 的 啊 应 信号。 


当 Modem 之 类 设备 已 准备 好 接收 终端 传 来 的 数据 并 向 前 发 送 时 ， 
使 CTS 信 号 有 效 ， 通 知 终端 开始 沿 发 送 数 据 线 TxD 发 送 数据 。 这 对 
RTS/CTS 请 求 应 答 联 络 信号 用 于 半 双 工 Modem 系 统 中 发 送 方式 和 接收 
方式 之 间 的 切换 。 在 全 双 工 系统 中 ， 因 配置 双向 通道 ， 故 不 需要 
RTS/CTS 联 络 信号 。 


口 数据 载波 检 出 (Data Carrier dectection，DCD) : 第 8 脚 ， 又 称 接 
收 线 信号 检 出 (Received Line Detection，RLSD) ， 用 来 表示 DCE 已 接 
通通 信和 链 路 ， 告 知 DTE 准 备 接 收 数据 。 当 本 地 的 Modem 收 到 由 通信 链 
路 另 一 端 ( 远 地 ) 的 Modem 送 来 的 载波 信号 时 ， 使 RLSD 信 号 有 效 ， 通 
知 终端 准备 接收 ， 并 且 由 Modem 将 接收 下 来 的 载波 信号 解 调 成 数据 信 
号 后 ， 沿 接收 数据 线 RxD 送 到 终端 。 


口 振 铃 指示 (Ringing，RI) : 第 22 脚 ， 当 Modem 收 到 交换 台 送 来 
的 振 铃 呼叫 信号 时 ， 使 该 信号 有 效 (ON 状态 ) ， 通 知 终端 ， 已 被 呼 
叫 。 


(2) 数据 发 送 与 接收 线 (2 和 3 引 脚 ) 


口 发 送 数据 (Transmitted data，TxD) : 第 2 脚 ， 通 过 TxD 终 端 将 串 
行 数据 发 送 到 Modem (DTE ~DCE) 。 


口 接收 数据 (Received data，RxD) : 第 3 脚 ， 通 过 RxD 线 终端 接收 
从 Modem 发 来 的 串 行 数据 DCE ~ DTE) 。 


(3) 地 线 〈1 引 脚 ) 


SG (7 脚 ) 、PE (1 脚 ) 分 别 用 来 接 信 号 地 和 保护 地 信号 线 ， 无 方 


上 述 控 制 信号 线 有 效 、 无 效 的 顺序 表示 了 接口 信号 的 传送 过 程 。 
例如 ， 只 有 当 DSR 和 DTR 都 处 于 有 效 (ON) 状态 时 ， 才 能 在 DTE 和 
DCE 之 间 进 行 传送 操作 。 帮 DTE 要 发 送 数 据 ， 则 预 完 将 DTR 线 置 成 有 
效 (ON) 状态 ， 等 CTS 线 上 收 到 有 效 (ON) 状态 的 回答 后 ， 才 能 在 
TxD 线 上 发 送 串 行 数据 。 这 种 顺序 的 规定 对 半 双 工 的 通信 线路 特别 有 
用 ， 因 为 半 双 工 的 通信 只有 确定 DCE 已 由 接收 方向 改 为 发 送 方 向 ， 这 
时 线路 才能 开始 发 送 。 


使 用 DB-9 连 接 器 ， 作 为 提供 多 功能 VO 卡 或 主板 上 COM1 和 COM2 
两 个 串 行 接 口 的 连接 器 。 它 只 提供 异步 通信 的 9 个 信号 。DB-25 型 连接 


铬 有 的 3 引 脚 分 配 与 DB-25 型 引 脚 信号 完全 不 同 。 因 此 ， 大 与 配 接 DB-25 型 
连接 器 的 DCE 设 备 连接 ， 必 须 使 用 专门 的 电缆 线 。 


在 连接 距离 上 ， 通 信 速 率 低 于 20kbps 时 ，RS-232C 直 接连 接 的 最 大 
物理 距离 为 15m (50 英 尺 ) 。 


2. 工 作 原 理 


言 号 的 标注 是 从 DTE 设 备 的 角度 出 发 的 ，TD、DTR 和 RITS 信 和 号 是 
由 DTE 产 生 的 ，RD、DSR、CTS、DCD 和 RI 信号 是 由 DCE 产 生 的 。 接 
地 信和 号 是 所 有 连接 公用 的 ， 在 有 的 标准 中 接地 信号 外 部 有 两 个 引 脚 ， 
事实 上 是 同一 个 信号 。 如 有 宁 两 个 通信 设备 的 距离 相差 的 很 远 或 者 有 两 
个 不 同 的 供电 系统 供电 ， 那 么 地 信和 号 在 两 个 设备 间 会 不 一 样 ， 从 而 导 
臻 通信 失败 ， 跟 踪 描 述 这 样 的 情形 是 很 困难 的 。 


收 、 发 端的 数据 信号 是 相对 于 信号 地 的 。 如 从 DTE 设 备 发 出 的 数 

据 在 使 用 DB-25 连 接 器 时 是 2 脚 相 对 7 脚 (信号 地 ) 的 电 平 。 典 型 的 RS- 
232 信 号 在 正 负电 和 平 之 间 摆 动 ， 在 发 送 数据 时 ， 发 送 端 驱动 器 输出 正 电 
平 在 +5~+15V 之 间 ， 负 电 平 在 -5~-15V 之 间 。 当 无 数据 传输 时 ， 线 上 为 
TIL， 从 开始 传送 数据 到 结束 ， 线 上 电 平 从 ITTL 电 平 到 RS-232 电 平 再 返 
回 TIL 电 平 。 接 收 絮 典型 的 工作 电 平 在 +3~+12V 与 -3~-12V 之 则 。 由 于 
发 送 电 平 与 接收 电 平 的 差 仅 为 2V 至 3V， 所 以 其 共 模 抑制 能 力 差 ， 再 加 
上 双 绞 线 上 的 分 布 电容 ， 其 传送 距离 最 大 为 约 15m， 最 高 速率 为 


20kbps。RS-232 是 为 点 对 点 〈 即 只 用 一 对 收 、 发 设备 ) 通信 设计 的 ， 
其 驱动 器 负载 为 (3~7) k9。 所 以 RS-232 适 合 本 地 设备 之 间 的 通信 。 


注意 “RS-232C 标 准 中 提 到 的 发 送 和 接收 ， 都 是 站 在 DTE 立 场 上 ， 
而 不 是 站 在 DCE 的 立场 来 定义 的 。 由 于 在 计算 机 系统 中 ， 往 往 是 CPU 
和 LO 设备 之 间 传 送信 息 ， 两 者 都 是 DTE， 因 此 双方 都 能 发 送 和 接收 。 


4.8.3 ”其 他 EIA 标 准 接口 


Kd 


余 了 前 面 介 绍 的 EIA-232 ( 即 RS-232) 接口 外 ， 在 EIA 接 口 标准 
中 ， 常 见 的 串 行 接口 协议 还 有 EIA-422、EIA-449、EIA-485、EIA-530 
等 ， 本 节 了 予以 简单 介绍 。 


EIA-422 (过 去 称 为 RS-422) 是 采用 4 线 、 全 双 工 、 差 分 传输 、 多 
点 通信 的 数据 传输 接口 协议 。 与 下 面 将 要 介绍 的 EIA-485 不 同 的 是 ， 
EIA-422 不 人 允许 出 现 多 个 发 送 病 ， 只 能 有 多 个 接收 端 (EIA-232 接 口 也 
可 以 有 多 个 接收 端 ) 。EIA-232 型 可 以 有 两 端口 、 四 端口 和 八 端口 等 几 
种 型 号 ， 而 EIA-422 型 接口 可 以 有 四 端口 、 八 端口 ， 甚 至 十 端口 等 几 种 


型 号 。 


EIA-422 传 输 信号 的 距离 和 速度 比 EIA-232 更 远 、 更 快 ， 并 旦 一般 
都 能 抗 电 子 干扰 和 电 涌 。 当 电缆 线 的 长 度 为 12m (40 码 ) 时 传输 速率 可 
以 达到 10Mbps。 由 于 EIA-422 具 有 上 述 优 点 ， 因 此 成 为 工业 、 制 造 业 以 
及 分 布 广泛 的 销售 经 营 企业 的 首选 产品 。 


EIA-422 的 通常 用 途 是 作为 RS-232 的 扩展 ， 是 RS-232 的 一 个 变种 。 
EIA-422 作 为 mini-DIN-8 连 接 器 标准 ， 在 被 USB 连 接 絮 取代 前 ， 曾 在 苹 
果 麦 金 托 什 (MAC) 电脑 上 大 量 使 用 。 


EIA-422 接 口 的 机 械 特 性 由 EIA-530 或 EIA-449 规 定 ， 然 而 设备 仅 有 
在 发 送 方 和 接受 方 成 对 出 现时 才 通 信 。 电 缆 的 最 高 传输 速率 在 长 度 为 
1.2m 时 为 10Mbps， 为 1200m 时 100kbps。EIA-422 不 能 实现 像 EIA-485 那 
样 的 真正 的 多 点 通信 ， 尽 管 其 一 个 发 送 端 就 可 以 连接 最 多 10 个 接收 


端 。 


EIA-449 〈 过 去 称 为 RS-449) 接口 协议 是 于 1992 年 9 月 发 布 的 。 它 
规定 了 数据 终端 设备 和 数据 通信 设备 之 间 的 接口 的 功能 特性 和 机 械 特 
性 。 规 定 RS-449 采 用 平衡 传输 时 的 电气 特性 的 协议 是 RS-422。 规 定 非 
平衡 传输 时 的 电气 特性 的 协议 是 RS-423， 数 据 的 传输 率 可 达 200kbps。 
协议 规定 了 两 个 D-sub 连 接 时 第 一 个 为 37 引 脚 ， 第 二 个 9 引 脚 。 尽 管 这 
种 协议 没有 在 个 人 电脑 上 使 用 ， 但 在 大 型 数据 交换 服务 器 上 还 是 很 常 
见 的 。 


EIA-485 〈 过 去 称 为 RS-485 或 RS485) 接口 协议 是 电力 特性 规定 为 2 
线 、 全 双 工 、 多 点 通信 的 标准 。 它 的 电力 特性 和 RS-232 大 不 一 样 。 用 
缆 线 两 端的 电压 差 值 来 表示 传递 信号 。1 端 的 电压 标识 为 逻辑 1， 另 一 
端 标识 为 逻辑 0。 两 端的 电压 差 为 0.2V 以 上 时 有 效 ， 任 何不 大 于 12V 或 
者 不 小 于 -7V 的 差 值 对 接收 问 来 说 都 是 正确 的 。 


EIA-485 仅 规定 了 接收 端 和 发 送 端的 电力 特性 ， 没 有 规定 或 推荐 任 
何 数据 协议 。 


EIA-485 可 用 于 配置 便宜 的 广域网 和 可 采用 单机 发 送 、 多 机 接收 的 
通信 联结 ， 可 提供 高 速 的 数据 通信 速率 〈 电 缆 长 10m 时 35Mbps， 电 缆 
长 200m 时 100kbps) 。EIA-485 和 EIA-422 一 样 使 用 双 绞 线 进 行 高 电压 差 
分 平衡 传输 ， 可 以 进行 大 面积 长 距离 传输 〈 最 长 为 1200m) 。 与 EIA- 
422 不 同 的 是 ，EIA-422 采 用 不 可 转换 的 单 发 送 端 ，EIA-485 的 发 送 端 需 
要 设置 为 发 送 模 式 ， 这 使 得 EIA-485 可 以 使 用 双 线 模式 实现 真正 的 多 点 
双向 通信 。 


EIA-485 推 荐 使 用 在 点 对 点 网 络 中 ， 如 线 型 、 总 线 型 拓扑 结构 的 网 
络 ， 但 不 能 是 星 型 、 环 型 网 络 。 理 想 情 况 下 EIA-485 需 要 2 个 终 接 电 
阻 ， 其 阻 值 要 求 等 于 传输 电缆 的 特性 阻抗 。 没 有 特性 阻抗 的 话 ， 当 所 
有 的 设备 都 静止 或 者 没有 能 量 的 时 候 就 会 产生 噪声 。 没 有 终 接 电阻 的 
话 ， 会 使 得 较 快速 的 发 送 端 产 生 多 个 数据 信号 的 边缘 ， 这 其 中 的 一 些 
是 不 正确 的 。EIA-485 不 能 用 在 星 型 或 者 环 型 的 拓扑 结构 中 ， 主 要 是 由 
于 在 这 些 结构 中 ，EIA-485 接 口中 过 低 或 者 过 高 的 终 接 电阻 会 产生 电磁 
可 


EIA-485 在 使 用 4 线 时 可 以 和 EIA-422 一 样 实现 全 双 工 ， 还 可 实现 真 
正 的 多 点 通信 。 在 某 些 限制 条 件 下 EIA-485 和 EIA-422 可 以 实现 相互 的 
连接 。 如 SCSI-2 和 SCSI-3 控 制 卡 通常 使 用 这 种 标准 的 设备 来 作为 物理 
层 。EIA-485 接 口 同样 可 以 在 一 些 工厂 的 项 目 控制 机 器 上 看 到 ， 来 实现 


工厂 不 同 楼 层 之 间 的 数据 通信 。 它 可 以 抵抗 机 械 设备 和 焊接 设备 的 电 
做 干扰 


EIA-485 还 可 以 在 大 型 音频 系统 中 使 用 ， 如 在 音乐 厅 和 剧院 中 通过 
这 种 接口 的 设备 就 可 以 使 用 普通 的 计算 机 来 运行 一 些 特殊 的 软件 以 实 
现 远 距离 音频 设备 的 控制 。EIA-485 通 过 XLR 标准 的 线 缆 连 接 的 设备 大 
量 用 于 麦克 风 上 ， 从 而 实现 舞台 和 控制 台 之 间 的 连接 而 无 须 预 设 线 
路 。 


表 4-4 列 出 了 EIA-485 的 一 些 特 性 、 引 脚 的 分 配 以 及 和 RS-232 的 比 


较 。 


表 4-4 EIA-485 的 一 些 特 性 、 引 脚 的 分 配 以 及 和 RS-232 的 比较 


Clear To Send + (CTS+) / 
4 
5 


| 


iD 


Received Data + (RxD+) Data Terminal Ready (DTR) 0 
Clear To Send - (CTS-) Data Set Ready (DSR) 6 


Ld 


EIA-485 RS-232 DB-25 DE-9 
Ready To Send - (RTS-) Request To Send (RTS) 7 
Transmitted Data + (TxD+) Clear To Send (CTS) 8 


4.8.4 X.21、X.24、X.36 和 EIA-530 接 口 规范 


除了 在 前 面 介 绍 的 RS-232 物 理 层 接口 处， 目前 在 广域网 的 网 络 连 
接 中 ， 常 用 的 其 他 物理 接口 还 有 X.21、X.24、X.36 和 EIA-530 这 四 种 。 
本 节 将 简单 对 这 些 物理 接口 规范 进行 介绍 。 


X.21 一 开始 是 CCITT 在 1976 年 以 建议 的 形式 向 外 外 发 布 的 ， 它 定义 
了 用 户 计算 机 的 DIE 如 何 与 数字 化 的 DCE 交 换 信号 的 数字 接口 标准 。 
X.21 的 设计 目标 之 一 是 要 减少 RS-232 之 类 的 串 行 接口 中 的 信号 线 的 数 
目 ， 其 采用 15 心 标准 连接 器 代替 原来 的 25 必 连接 锋 ， 而 且 其 中 仅 定 义 
了 8 条 接口 线 。 


X.21 的 另外 一 个 设计 目标 是 允许 接口 在 比 EIA RS-232C 更 长 的 距离 
上 进行 更 高 速率 的 数据 传输 ， 其 电气 特性 类 似 于 EIA RS-422 的 平衡 接 
口 ， 文 持 最 大 的 DIE-DCE 电 缆 距 离 是 300m。X.21 可 以 按 同 步 传输 的 半 
双 工 或 全 双 工 方式 和 运行， 传输 速率 最 大 可 达 10Mbps。X.21 接 口 适 用 于 
通过 数字 线路 (而 不 是 模拟 线路 ) 访问 公共 数据 网 (PDN) 的 地 区 。 
欧洲 网 络 大 多 使 用 X.21 接 口 。 


XX.21 接 口 的 15 针 连接 右 中 定义 了 8 条 功能 线 。 分 成 4 个 工作 阶段 : 
空 内 ， 呼 叫 控 制 ， 数 据 传送 ， 清 除 。X.21 接 口 的 接口 规范 如 表 4-5 所 


示 。X.24 DTE 接 口 规范 、X.24 DCE 接 口 规范 、X.36 和 EIA-530 接 口 规范 
分 别 如 表 4-6、 表 4-7、 表 4-8、 表 4-9 所 示 。 


表 4-5 X.21 接口 规范 
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表 4-7 V.24 DCE 接口 规范 
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表 4-8 V.36/RS-449 接口 规范 
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表 4-9 ”EIA-530 接口 规范 
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DSR+ 输 
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发 送 时 钟 (DCE) 
接收 数据 
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数据 终端 就 绪 
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清除 发 送 
数据 设备 就 绪 
数据 终端 就 绪 
数据 载波 检测 
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说 明 
保护 接地 
发 送 数 据 
接收 数据 

请 求 发 送 
清除 发 送 
数据 设备 就 结 
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数据 载波 检测 
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说 明 
接收 时 钟 (DCE) 
数据 载波 检测 
发 送 时 钟 (DTE) 
发 送 时 钟 (DCE) 
清除 发 送 
发 送 数 据 
发 送 时 钟 (DCE) 
接收 数据 
接收 时 钟 (DCE) 
本 地 回环 
请 求 发 送 
数据 终端 就 绪 
远程 回环 
数据 设备 就 绪 
数据 终端 就 绪 
发 送 时 钟 (DTE) 
测试 指示 器 


第 5 章 ”数据 链 路 层 


要 在 一 条 通信 线路 上 传送 数据 ， 除 了 必须 建立 一 条 物理 线路 ( 物 
理 层 的 功能 ， 之 外 ， 还 必须 有 一 些 规程 或 协议 来 控制 这 些 数 据 的 传 
输 ， 以 保证 被 传输 数据 的 正确 性 。 实 现 这 些 规程 或 协议 的 硬件 和 软件 
加 上 物理 线路 就 构成 了 本 章 要 介绍 的 “数据 链 路 层 ” (Data Link Layer， 
DLL) 。 


我 们 知道 ， 物 理 层 中 也 有 许多 规程 或 协议 ,但 它们 是 用 来 构建 物 
理 传输 线路 、 建 立 物 理 意义 的 网 络 通 信 ， 不 是 用 来 控制 数据 传输 的 。 
设计 数据 链 路 层 的 主要 目的 融 是 在 原始 的 、 有 老 钳 的 物理 传输 线路 的 
基础 上 ， 采 取 关 镜 检 测 、 关 销 欣 制 与 流量 控制 等 方法 ， 将 有 老 钳 的 物 
理 线路 改进 成 逻辑 上 无 差错 的 数据 链 路 ， 以 便 同 它 的 上 一 层 一 一 网 络 
层 提供 高 质量 的 服务 。 就 像 我 们 修好 了 路 ， 还 得 制定 一 些 交 通 法 规 ， 
使 路 上 行驶 的 车 辆 必须 按照 一 定 的 规则 行驶 ， 人 否则 可 能 会 经 闻 出 现 交 
通 事故 。 这 些 “ 交 通 法 规 ” 也 为 了 使 这 些 车 辆 到 达 某 个 车 站 (这 里 所 说 
的 “车 站 ” 束 相 当 于 计算 机 网 络 体系 结构 中 的 “网 络 层 ”) 时 能 有 序 进 、 出 
站 ， 最 终 使 这 条 数据 通信 之 “路 "发挥 它 本 来 的 作用 。 


在 不 同 网 络 体系 结构 中 ， 数 据 链 路 层 的 结构 和 所 包括 的 功能 并 不 
完全 一 样 。 本 章 主 要 针对 广域网 中 的 数据 链 路 层 和 局 域 网 体系 结构 中 
的 逻辑 链 路 控制 (LLC) 子 层 的 功能 及 相关 技术 进行 全 面 、 深 入 的 介 


绍 。 读 者 要 着 重要 掌握 的 是 数据 链 路 层 的 链 路 管理 、 数 据 帧 封装 、 差 
错 控 制 、 流 量 控制 这 儿 项 功能 的 实现 原理 ，BSC、SDLC、HDLC 和 PPP 
这 几 种 典型 的 数据 链 路 层 协议 及 二 交换 原理 。 有 关 局 域 网 体系 结构 中 
的 媒介 访问 控制 (MAC) 子 层 的 功能 和 相关 技术 将 在 下 草 介 绍 。 


5.1 数据 链 路 层 基础 


在 所 有 计算 机 网 络 体系 结构 中 都 直接 或 间接 地 包含 了 数据 链 路 层 
(在 TCP/IP 协 议 体 系 结构 中 数据 链 路 层 的 功能 包含 在 网 络 访问 层 
中 ) 。 数 据 链 路 层 和 它 下 面 的 物理 层 其 实 本 质 作 用 都 是 一 样 的 ， 就 是 
用 来 构建 进行 网 络 通信 、 访问 的 通道 ， 只 不 过 物理 层 构建 的 是 一 条 物 
理 通道 ， 而 数据 链 路 层 构建 的 是 真正 用 于 数据 传输 的 逻辑 通道 。 正 因 
如 此 ， 在 目前 Internet 中 广泛 使 用 的 TCP/AP 协 议 体 系 结构 中 ， 物 理 层 和 
数据 链 路 层 是 集中 划分 在 网 络 访问 层 这 一 层 之 中 的 。 


5.1.1 划分 数据 链 路 层 的 必要 性 


虽然 说 物理 层 和 数据 链 路 层 的 本 质 作 用 都 是 用 来 构建 网 络 通信 、 
访问 通道 ， 但 它们 所 建立 的 通信 通道 是 不 一 样 的 。 首 移 要 说 明 的 一 点 
征 ， 在 物理 层 上 构建 的 是 物理 链 路 ， 在 数据 链 路 层 上 构建 的 是 逻辑 链 
路 或 者 数据 链 路 ， 它 们 是 不 同 的 概念 ， 但 确实 有 许多 读者 分 不 清楚 。 


物理 链 路 是 指 在 物理 层 设备 (包括 传输 介质 、 物 理 接口 和 收发 右 
等 ) 和 相应 物理 层 通 信 规 程 作用 下 形成 的 物理 线路 ， 是 永久 存在 的 ， 
且 是 不 可 删除 的 除非 物理 拆除 ) ;逻辑 链 路 则 是 通信 双方 在 需要 进 
行 数据 通信 时 ， 在 数据 链 路 层 设备 和 相应 的 通信 规程 作用 下 建立 的 人 逻 
辑 链 路 ， 可 以 是 永远 存在 的 (如 局 域 网 中 的 以 太 网 链 路 ) ， 也 可 以 不 
是 永久 存在 的 〈 如 广域网 中 的 链 路 ) ， 是 否 永久 存在 要 视 具体 的 数据 
链 路 层 服 务 类 型 而 定 。 这 里 还 有 一 个 “ 链 路 ”的 概念 ， 它 是 指 相 邻 广 点 
之 间 的 那 段 数据 线路 。 


在 看 到 物理 链 路 和 逻辑 链 路 之 间 区 别 的 同时 ， 又 要 看 到 它们 之 间 
的 联系 ， 那 就 是 逻辑 链 路 必须 建立 在 物理 链 路 之 上 。 如 果 通 信 双 方 的 
物理 线路 都 不 通 ， 是 不 可 能 建立 用 于 数据 传输 的 逻辑 链 路 的 。 我 们 可 
以 这 样 来 理解 它们 之 间 的 关系 ， 物 理 链 路 是 基础 线路 ， 相 当 于 一 条 公 
路 的 路 基 ， 而 逻辑 链 路 是 在 物理 链 路 之 上 的 高 级 线路 ， 可 以 理解 为 在 
公路 上 铺设 了 相 油 或 者 水 泥 的 车 道 。 它 们 之 间 的 关系 如 图 5-1 所 示 。 


发 送 病 接收 端 


数据 链 路 层 逻辑 链 吕 数据 链 路 层 


图 5-1 “物理 链 路 * 和 “ 辑 链 路 ”的 天 系 


无 论 在 多 么 复杂 的 网 络 中 ， 从 逻辑 意义 上 来 讲 ， 真 正 的 数据 传输 
通道 束 古 数据 链 路 层 中 所 定义 的 数据 链 路 ， 只 不 过 在 要 经 过 多 个 网 络 
的 数据 通信 中 ， 数 据 链 路 是 分 段 的 ， 每 个 网 络 都 有 一 段 链 路 ， 这 些 链 
路 段 连 搂 起 来 束 整 个 效 据 通 信 的 数据 链 路 。 网 5-2 所 示 的 是 一 个 有 三 
个 网 段 经 过 两 个 路 由 器 〈 路 由 器 A 和 路 由 器 B) 相连 的 网 络 ， 现 假设 PC 
用 户 A 要 癌 PC 用 户 B 发 送 一 个 数据 ， 它 的 实际 数据 传输 过 程 如 图 5-2 中 
各 网 络 物理 层 之 间 的 实 线 箭头 所 示 ， 而 逻辑 上 可 以 等 同 各 部 分 数据 链 
路 层 之 间 构 建 的 “逻辑 链 路 "之 间 的 数据 转发 ， 如 图 5-2 中 虚线 箭头 所 


尔 。 


图 5-2 数据 在 网 络 中 的 传输 方 问 


说 到 这 里 ， 可 能 有 的 读者 会 问 ， 既 然 在 “物理 层 " 中 构建 了 数据 传 
输 通道 〈 也 就 是 物理 层 中 的 “信道 ， 那 为 什么 还 要 多 加 一 个 “数据 链 
路 层 ?的 功能 呢 ? 其实 这 主要 有 两 方面 的 原因 : 


口 一 是 由 于 物理 层 传输 介质 的 多 样 性 ， 通 信 规 程 也 各 不 相同 ， 性 
能 不 稳定 ， 而 数据 链 路 层 中 构建 的 逻辑 链 路 不 考虑 不 同 物理 链 路 上 传 
输 介 质 及 其 通信 规程 上 的 区 别 (也 就 是 我 们 通常 所 说 的 数据 链 路 层 可 
以 屏蔽 物理 层 中 传输 介质 的 不 同 ) ， 只 是 从 逻辑 意义 上 构建 一 条 性 能 
稳定 、 不 受 传输 介质 类 型 影响 的 逻辑 数据 传输 通道 。 束 像 修建 公路 
时 ， 所 用 的 材质 也 可 能 不 一 样 ， 有 的 用 普通 的 泥巴 ， 有 的 用 沙 石 ， 还 
有 的 用 大 石材 。 如 果 仅 靠 一 些 基 础 材料 修建 公路 ， 可 能 修好 的 公路 通 
车 性 能 很 差 ， 有 的 甚至 根本 不 能 通车 ， 只 能 步行 。 但 如 果 我 们 在 这 些 


公路 上 再 统一 铺 一 层 钢 筋 混凝土 ， 那 么 这 些 由 不 同 材 料 修建 的 公路 就 
可 能 满足 基本 相同 的 通车 性 能 的 要 求 了 。 


口 再 一 个 原因 古 ， 在 物理 层 中 数据 十 一 位 位 地 单独 传输 的 ， 不 仅 
数据 传输 效率 低下 ， 而 且 容 易 出 现 数据 传输 差错 《如 出 现 某 些 数据 位 
丢失 或 者 错位 ， 在 物理 层 中 叉 没 有 相应 的 通信 规程 进行 数据 传输 差错 
控制 ) ， 就 像 一 条 不 能 通车 的 普通 公路 上 ， 人 只 能 一 个 个 地 步行 ， 还 
可 能 出 现 迷路 现象 一 样 。 而 在 数据 链 路 层 中 数据 是 以 * 帧 ”为 单位 进行 
传输 的 ， 一 个 帧 通常 是 有 数 千 个 比特 位 的 ， 不 仅 传输 效率 提高 ， 还 不 
容易 出 错 〈 因 为 在 数据 链 路 层 中 有 专门 的 通信 规程 来 负责 数据 传输 差 
错 控制 ) ， 就 像 在 能 通车 的 公路 上 以 车 为 单位 运载 人 一 样 ， 不 仅 传输 
效率 提高 ， 还 不 容易 出 现 各 种 交通 事故 。 至 于 数据 链 路 层 的 主要 功 

章 后 具 


5.1.2 ”数据 链 路 层 结构 


在 正式 介绍 “数据 链 路 层 ” 主 要 功能 和 实现 原理 前 ， 我 们 先 要 明 
日 ， 各 种 计算 机 网 络 体系 结构 中 ， 数 据 链 路 层 的 结构 是 不 完全 一 样 
的 。 在 OSUVRM 和 TCP/PP 体 系 结构 中 ， 数 据 链 路 层 束 一 层 ， 而 在 局 域 网 
体系 结构 中 是 可 细 分 为 两 个 子 层 的 ， 那 就 是 逻辑 链 路 控制 (Logical 
Link Control，LLC) 子 层 和 介质 访问 控制 (Medium Access Control， 
MAC) 子 层 ， 如 图 5-3 所 示 。 


MAC 子 层 


图 5-3 局 域 网 体系 结构 “数据 链 路 层 ” 的 两 个 子 层 


经 验 之 谈 设置 MAC 于 层 的 目的 主要 是 解决 多 路 通信 的 介质 争 用 
和 寻 址 ， 所 以 其 主要 适用 于 广播 型 链 路 和 点 对 多 点 链 路 。 对 于 点 对 点 


链 路 来 说 ， 没 什么 太 大 意义 ， 因 为 点 对 点 链 路 不 存在 介质 争 用 ， 是 一 
路 通信 所 独占 的 。 具 体 将 在 下 章 介绍 。 


从 图 5-3 可 以 看 出 ， 在 数据 链 路 层 中 ， 与 它 的 下 一 层 一 一 物理 层 相 
邻 的 是 MAC 子 层 ， 与 它 的 上 一 层 一 一 网 络 层 相 邻 的 是 LLC 子 层 。 所 以 
MAC 子 层 接受 物理 层 的 服务 ， 为 LLC 子 层 服务 ， 而 LLC 子 层 则 是 接受 
MAC 子 层 服务 ， 为 网 络 层 服 务 。 而 各 层 〈 其 他 层 也 一 样 ) 之 间接 受 服 
务 或 者 提供 服务 的 地 方 就 是 SAP (Service Access Point， 服 务 访问 
点 ) 。 下 面 完 来 了 解 什么 是 SAP 。 


1. 各 层 的 SAP 


从 SAP 的 中 文 名 称 “ 服 务 访问 点 ”可 以 看 出 ， 它 就 是 上 层 访问 相 邻 下 
层 所 提供 服务 的 点 。 我 们 知道 ， 在 计算 机 体系 结构 中 ， 下 层 是 为 相 邻 
的 上 层 提供 服务 的 ， 而 下 层 对 它 的 所 有 上 层 都 是 透明 的 。 也 了 束 是 上 层 
\ 会 具体 管 它 的 下 面 各 层 是 如 何 工 作 的 ， 只 需要 它 的 相 邻 下 层 提 供 必 
要 的 服务 即 可 。 


SAP 是 邻 层 实体 〈“ 实 体 " 也 就 是 对 应 层 的 逻辑 功能 ) 间 实 现 相互 通 
信 的 逻辑 接口 ， 位 于 两 层 边界 处 。 从 物理 层 开始 ， 每 一 层 都 向 上 层 提 
供 服 务 访问 点 (应 用 层 除外 ) ， 每 一 层 都 有 SAP， 但 不 同 层 的 SAP 内 容 
和 表示 形式 都 是 不 一 样 的 。 各 层 SAP 的 表示 形式 是 对 应 层 第 一 个 单词 的 
第 一 个 字母 加 上 “SAP”， 如 物理 层 SAP 表 示 为 PSAP (Physical layer 


Service Access Point) ， 对 应 的 就 是 网 络 通信 中 设备 的 具体 物理 接口 
数据 链 路 层 SAP 表 示 为 DLSAP (Data Link Control layer Service Access 
Point) ， 对 应 的 就 是 各 个 物理 接口 的 MAC 地 址 ; 网络 层 SAP 表 示 为 

NSAP (Network layer Service Access Point) ， 对 应 的 就 是 各 物理 接口 
上 配置 的 网 络 地 址 (如 IP 地 址 ， 但 在 OSVRM 中 网 络 地 址 不 一 定 是 IP 地 
址 ， 要 视 具 体 的 网 络 层 协议 而 定 ， 如 还 可 以 是 IPX 地 址 ) ; 传输 层 SAP 
表示 为 TSAP (Transport layer Service Access Point) ， 对 应 的 就 是 具体 
网 络 应 用 通信 所 用 的 传输 层 端口 ;会 话 层 SAP 表 示 为 SLSAP (Session 
layer Service Access Point) ， 对 应 的 就 是 具体 网 络 应 用 会 话 进程 ; 表示 
层 SAP 表 示 为 PLSAP (Presentation layer Service Access Point) ， 对 应 的 
就 是 具体 网 络 应 用 进程 中 的 用 户 标识 。 


从 以 上 介绍 可 以 得 知 ， 其 实 SAP 每 层 所 对 应 的 “地 址 ”， 但 是 针对 一 
个 具体 的 网 络 通信 (注意 ， 这 里 特别 说 明 一 下 不 是 数据 通信 ) 来 说 ， 
不 同 层 中 的 SAP 数 是 不 一 样 的 。 如 物理 层 的 PSAP 只 有 一 个 (就 是 对 应 
的 物理 接口 ) ， 数 据 链 路 层 的 DLSAP 也 只 有 一 个 (就 是 对 应 物理 接口 
的 MAC 地 址 ) ， 在 网 络 层 中 虽然 每 个 物理 接口 可 以 有 多 个 IP 地 址 ， 但 
是 对 于 一 个 具体 的 数据 通信 来 说 ， 它 也 只 有 一 个 ， 所 以 NSAP 也 只 有 一 
个 ， 传 输 层 及 以 上 各 层 的 SAP 束 可 以 有 多 个 了 人 ， 因 为 每 一 个 网 络 通 信 中 
可 以 同时 进行 多 路 网 络 应 用 (当前 有 和 多少 个 网 络 应 用 进程 ， 就 需要 多 
少 个 SAP) ， 实 现 多 路 数据 通信 。 正 因 如 此 ， 针 对 一 个 具体 的 网 络 通信 
中 各 层 的 SAP 可 以 描述 为 图 5-4 所 示 的 形式 。 


应 用 层 


NSAP 


网 络 层 


DLSAP 
PSAP 


图 5-4 OSIURM 各 层 的 SAP 


2MAC 子 屋 


从 *MAC” 的 中 文 名 称 “ 介 质 访 问 探 制 " 可 以 看 出 ，MAC 子 层 的 最 基 
本 功能 殉 是 如 何 控制 不 同 用 户 数据 传输 中 对 物理 层 传输 介质 的 访问 ， 
其 中 包括 介质 访问 时 的 寻 址 (这 里 是 通过 MAC 地 址 进行 的 ) ， 以 及 解 
决 可 能 发 生 的 介质 访问 冲突 (也 就 是 我 们 通常 昕 到 的 “仲裁 介质 的 使 用 
权 ”， 即 规定 站 点 何 时 可 以 使 用 通信 介质 ) 。 如 IEEE 802.3 以 太 网 标准 


MAC 子 层 规范 了 如 何在 总 线 型 网 络 结构 下 使 用 传输 介质 ; IEEE 802.4 
令 牌 总 线 (Token-Bus) 标准 MAC 子 层 规范 了 如 何在 总 线 的 网 络 结构 下 
利用 令 牌 (token) 控制 传输 介质 的 使 用 ，IEEE 802.5 令 牌 环 (Token- 
Ring) 标准 MAC 子 层 规范 了 如 何在 环 状 网 络 结构 下 利用 令 牌 来 控制 传 
输 介质 的 使 用 ，IEEE 802.11 标 准 的 无 线 局 域 网 标准 MAC 子 层 规范 了 如 
何在 无 线 局 域 网 络 的 结构 下 控制 传输 介质 的 使 用 。 


具体 而 言 ， 数 据 链 路 层 中 与 各 种 传输 介质 访问 有 关 的 问题 都 放 
在 “MAC 了 于 层 " 来 解决 。 其 主要 功能 包括 : 数据 帆 的 封装/ 外 又 ， 烦 的 寻 
址 和 识别 ， 帧 的 接收 与 发 送 ， 巾 的 差错 控制 、 介 质 访问 冲突 控制 等 。 
有 关 MAC 子 层 的 具体 功能 和 技术 介绍 将 在 下 章 进行 。 


二 屋 


从 “LLC”* 的 中 文 名 称 “ 逻 辑 链 路 控制 "可 以 看 出 ，LLC 子 层 的 最 基本 
功能 就 是 负责 数据 链 路 层 中 逻辑 链 路 (逻辑 链 路 就 是 物理 层 信 道中 的 
物理 链 路 在 通过 LLC 子 层 协议 作用 后 形成 的 虚拟 链 路 ) 的 控制 ， 其 中 
包括 逻辑 链 路 的 建立 和 释放 ， 控 制 信号 交换 、 数 据 流量 控制 ， 解 释 上 
层 通 信 协 议 传 来 的 命令 并 且 产 生 响 应 ， 以 及 克服 数据 在 传送 的 过 程 当 
中 所 可 能 发 生 的 种 种 问题 ， 如 数据 发 生 错误 、 重 复 收 到 相同 的 数据 、 
接收 数据 的 顺序 与 传送 的 顺序 不 一 臻 等。 在 LLC 子 层 方面 ，IEEE 802 系 
列 标准 中 只 制定 了 一 种 标准 一 一 IEEE 802.2， 各 种 不 同 局 域 网 都 使 用 相 
同 的 LLC 子 层 通信 标准 。 


由 于 网 络 层 上 可 能 有 许多 种 通信 协议 同时 存在 ， 而 且 每 一 种 通信 
协议 又 可 能 同时 与 多 个 对 象 沟 通 ， 因 此 当 LLC 子 层 从 MAC 子 层 收 到 一 
个 数据 包 时 必须 能 够 判断 要 送 给 网 络 层 的 是 哪 一 个 通信 协议 。 为 了 达 
到 这 种 功能 ， 在 LLC 子 层 中 提供 了 “ 煞 据 链 路 层 ” 的 SAAP， 作 为 与 “网 络 
层 ” 通 信人 交互 的 接口 (每 路 通信 和 需要 一 个 SAP 接 口 ， 如 图 5-5 所 示 ) 。 为 
了 能 够 辨认 出 LLC 子 层 上 传送 的 数据 从 哪里 来 ， 要 到 哪里 去 ， 在 LLC 子 
层 上 传输 的 每 个 LLC 数 据 单元 (LLC Protocol Data Unit，LPDU) 上 都 


会 有 “目的 服务 访问 点 ”(Destination Service Access Point，DSAP) 
和 “ 源 服 务 访问 点 ”(Source Service Access Point，SSAP) 这 两 个 地 址 。 
具体 的 LPDU 帧 格式 将 在 本 章 后 面 介 绍 。 


在 计算 机 网 络 中 进行 的 数据 传输 ， 虽 然 实际 上 有 是 从 发 送 端的 高 层 
一 路 经 过 数据 链 路 层 、 物 理 层 ， 然 后 再 从 接收 问 的 物理 层 、 数 据 链 路 
层 一 直 传输 到 对 应 的 高 层 〈 如 图 5-5 中 实 线 箭头 所 示 ) ， 而 从 逻辑 意义 
看 ， 数 据 十 从 发 送 闻 数据 链 路 层 到 接收 问 数 据 链 路 层 间 的 一 段 段 逻辑 
链 路 上 进行 传输 的 〈 如 图 5-5 中 虚线 箭头 所 示 ) ， 因 为 在 物理 层 中 传输 
的 比特 流 最 终 还 是 要 转换 成 数据 帆 在 数据 链 路 层 中 传输 。 


发 送 端 接收 天 


网 络 层 


数据 链 路 层 


图 5-5 LLC 子 层 的 SAP 及 数据 传输 原理 示例 


5.2 ”数据 链 路 层 主 要 功能 及 实现 原理 


数据 链 路 层 位 于 网 络 体 系 结构 中 “网 络 层 ”( 在 TCP/IP 协 议 体 系 结 
构 中 称 网 际 互 连 层 ) 的 下 层 ， 所 以 它 的 一 项 基本 功能 就 是 向 网 络 层 提 
供 透 明 、 可 人 靠 的 数据 传输 服务 (在 计算 机 网 络 体系 结构 中 ， 下 一 层 是 
为 相 邻 的 上 一 层 服 务 的 ) 。*“ 透 明 ” 是 指 要 使 在 数据 链 路 层 上 所 传输 的 
数据 在 内 容 、 格 式 及 编码 上 都 没有 限制 ， 也 束 是 要 使 一 些 本 来 用 于 特 
殊 用 途 的 控制 字符 《有 具体 有 哪些 控制 字符 将 在 本 章 后 面 介绍 ) 也 能 像 
正常 的 数据 一 样 传输 ， 使 接收 闯 不 要 误 认 为 这 些 字符 为 控制 字符 ; 可 
靠 的 传输 使 数据 从 发 送 端 无 过错 地 在 数据 链 路 上 传输 到 目的 接收 端 。 
总 体 而 言 ， 数 据 链 路 层 (其 实 这 里 主要 是 针对 LLC 子 层 ) 的 主要 功能 
忠 古 四 个 方面 :数据 链 路 管理 、 封 汉 成 巾 、 透 明 传 输 、 差 错 控 制 。 下 


面具 体 介绍 。 


5.2.1 ”数据 链 路 管理 


在 本 章 前 面 说 到 了 ， 在 数据 链 路 层 中 要 形成 一 条 更 有 利于 数据 传 
输 的 数据 链 路 ， 而 不 是 直接 利用 下 面 物理 层 中 建立 的 物理 链 路 。 物 理 
链 路 在 没有 人 为 拆除 时 是 永久 存在 的 ， 而 数据 链 路 一 般 是 非 永 久 存 在 
的 《但 局 域 网 中 的 数据 链 路 是 永久 的 ) ， 仅 当 有 数据 传输 时 建立 并 存 


在 ， 在 数据 传输 完 后 目 动 拆除 。 数 据 链 路 是 由 数据 链 路 层 中 的 LLC 于 
层 通过 相应 的 通信 规程 (也 就 是 通常 所 说 的 协议 ) 建立 并 管理 的 。 


说 明 ”数据 链 路 分 为 点 对 点 链 路 和 点 对 多 点 链 路 (或 “广播 链 
路 *) 两 种 。 点 对 点 链 路 就 是 一 个 节点 只 与 另 一 个 节点 连接 起 来 的 链 
路 ， 用 于 建立 点 对 点 通信 。 它 所 采用 的 是 点 对 点 协议 ， 如 PPP (点 对 
点 协议 ) ，PPPoE (基于 以 太 网 的 点 对 点 协议 ) 。 点 对 多 点 链 路 就 是 
一 个 节点 同时 与 多 个 节点 连接 建立 起 来 的 链 路 ， 用 于 建立 点 对 多 点 通 
言 。 它 所 采用 的 通常 是 点 对 多 点 协议 ， 如 以 太 网 协议 、WLAN 协 议 ， 
还 有 本 章 后 面 将 要 介绍 的 HDLC (高 级 数据 链 路 控制 ) 协议 。 


1 .数据 链 路 层 提供 的 服务 类 型 


根据 数据 链 路 层 协议 的 不 同 ， 所 建立 的 数据 链 路 类 型 也 会 有 不 
同 。 同 时 我 们 知道 ， 数 据 链 路 层 是 为 上 面 的 网 络 层 提供 服务 的 ， 所 以 
这 些 不 同 协议 所 建立 的 数据 链 路 加 网 络 层 提供 的 服务 类 型 也 有 所 不 
同 。 总 体 上 可 把 这 些 数据 链 路 服务 分 为 以 下 三 类 : 有 确认 的 面向 连接 
服务 、 有 确认 的 无 连接 服务 、 无 确认 的 无 连接 服务 。 前 者 称 为 面向 连 
接 服务 (Connection-oriented Servce) ， 后 面 两 者 称 为 无 连接 服务 


(Connetionless Service) 。 


说 明 ”其 实 不 仅 本 章 中 所 讲 的 数据 链 路 层 协议 有 面 癌 连接 和 无 连 
接 两 种 服务 类 型 ， 在 网 络 层 和 传输 层 协议 中 也 有 这 两 种 类 型 的 ， 如 网 


络 层 中 的 X.25 协 议 是 面向 连接 的 ， 而 IP 协 议 则 是 无 连接 的 ， 传 输 层 中 
的 TCP 协 议 是 面向 连接 的 ， 而 UDP 协议 是 无 连接 的 。 这 些 将 在 第 10 章 


WT I 


(1) 有 确认 的 面向 连接 服务 


有 确认 的 面向 连接 服务 里 面包 括 两 层 含义 :一 是 在 提供 服务 时 ， 
必须 先 建立 好 双方 通信 连接 ， 二 是 在 提供 服务 时 ， 必 须要 求 对 方 确 认 
后 才 进 行 。 这 种 服务 类 型 存在 三 个 阶段 ， 即 数据 链 路 建立 、 数 据 传 
输 、 数 据 链 路 释放 等 阶段 。 举 个 现实 中 的 例子 ， 整 像 我 们 打 电 话 ， 我 
们 打 电 话 给 某 个 人 时 ， 首 先 就 是 要 拿 起 电话 拨号 (相当 于 建立 连接 的 
过 程 ，， 然 后 对 方 拿 起 电话 ， 间 一 下 看 是 不 是 打 错 了 (这 就 是 一 个 “ 确 
认 ” 过 程 ) 。 确 认 不 是 打 错 的 电话 后 ， 双 方 开始 通话 ， 这 就 相当 于 在 数 
据 链 路 中 进行 数据 传输 的 过 程 ， 通 话 完毕 ， 双 方 挂 掉 电话 ， 相 当 于 链 
路 释放 的 过 程 。 


从 以 上 这 个 打 电 话 的 例子 可 以 看 出 ， 数 据 链 路 层 中 有 确认 的 面 癌 
连接 服务 是 独占 链 路 的 ， 只 有 在 当前 数据 传输 完成 ， 释 放 了 链 路 后 ， 
其 他 用 户 才 可 能 与 同一 个 接收 端 进行 数据 传输 。 号 像 你 打 电 话 给 你 的 
朋友 时 ， 其 他 人 再 打 电 话 给 你 朋友 听 到 的 是 忙 音 ， 只 有 等 你 结束 了 与 
你 朋友 的 通话 后 ， 其 他 人 才 可 以 打通 你 那 朋 友 的 电话 。 同 样 ， 从 以 上 
分 析 可 以 得 出 ， 有 确认 的 面向 连接 服务 非常 可靠， 这 一 则 是 因为 有 专 
门 的 通信 和 链 路 ， 在 一 路 通信 使 用 某 条 链 路 时 ， 其 他 通信 不 能 同时 使 用 


这 条 链 路 ， 再 则 是 这 种 服务 类 型 不 会 同 错 误 的 接收 端 进行 数据 传输 ， 

也 可 确认 接收 端正 确 地 接收 了 发 送 来 的 数据 ， 而 且 有 古 按 数据 帧 发 送 顺 
序 接收 ， 每 一 帧 只 接收 了 一 次 ， 因 为 它 规定 接收 端 在 接收 到 每 一 个 数 
据 帧 (每 个 帧 都 有 编号 ) 后 必须 对 发 送 端 进行 确认 ， 束 像 打 电话 一 

样 ， 只 有 对 方 确认 你 是 要 找 他 的 ， 他 才 可 能 接听 你 的 电话 。 


大 多 数 广 域 网 中 通信 子 网 的 数据 链 路 层 协 议 采 用 有 确认 的 面向 连 
接 服务 ， 如 SLIP 〈 串 行 线路 协议 ) 、PPP (点 对 点 协议 ) 、PPPoE ( 基 
于 以 太 网 的 点 对 点 协议 ) 、HDLC (高 级 数据 链 路 控制 ) 协议 等 。 


(2) 有 确认 的 无 连接 服务 


有 确认 的 无 连接 服务 与 有 确认 的 面向 连接 服务 的 相同 之 处 就 古 接 
收 闯 在 接收 到 的 每 一 个 数据 帧 时 都 癌 发 送 端 确认 ; 不 同 之 处 在 于 它 在 
进行 数据 传输 前 是 不 需要 建立 专门 的 数据 链 路 的 ， 目 然 也 不 需要 在 数 
据 传输 结束 后 释放 数据 链 路 (事实 上 是 因为 这 类 服务 所 用 的 数据 链 路 
已 建立 起 来 ， 而 且 是 永久 存在 的 ， 所 以 不 用 另外 建立 ， 如 局 域 网 中 的 
链 路 ) 。 就 像 我 们 从 快递 公司 寄 快 递 信件 一 样 ， 信 的 投递 路 线 我 们 不 
用 管 (事实 上 投递 路 线 已 经 有 了 ) ， 但 是 在 收 件 人 收 到 信件 时 必须 要 
求 收 件 人 签收 〈 也 束 是 要 对 接收 到 的 每 一 个 数据 帧 进行 确认 ) 。 


有 确认 的 无 连接 服务 虽然 不 用 建立 专门 的 连接 ， 但 仍 可 以 保证 数 
据 的 可 靠 传输 ， 因 为 它 有 "确认 ?功能 ， 如 令 牌 环 网 和 令 牌 总 线 网 中 的 


数据 传输 就 古 采 用 这 种 服务 类 型 ， 接 收 端 在 接收 到 一 个 数据 帧 时 会 发 
送 确认 信息 给 发 送 端 的 。 这 类 服务 的 男 外 一 个 主要 用 途 就 古 用 于 一 些 
不 可 靠 信 道中 的 数据 传输 ， 如 各 种 无 线 通 信和 系统 。 


(3) 无 确认 的 无 连接 服务 


无 确认 的 无 连接 服务 与 前 面 的 有 确认 的 无 连接 服务 的 相同 之 处 惑 
在 于 它们 都 不 需要 在 进行 数据 传输 前 先 建立 专门 的 数据 链 路 ， 也 束 是 
无 须 允 在 通信 双方 建立 通信 和 连接; 不 同 之 处 就 是 它 在 进行 数据 传输 时 
不 要 求 接收 端 对 所 接收 到 的 每 一 个 数据 帧 进行 确认 。 驳 像 我 们 从 邮局 
寄 平 信 一 样 ， 信 件 投递 路 线 我 们 不 用 管 (事实 上 投递 路 线 已 经 有 
了 ) ， 而 且 当 信件 到 达 收 信人 时 ， 也 不 用 收 件 人 签名 确认 。 


这 种 服务 类 型 看 似 不 可 靠 ， 但 它 征 建立 在 可 靠 的 通信 线路 基础 之 
上 的 ， 所 以 数据 传输 仍然 是 非常 可 靠 的 。 如 我 们 常用 的 以 太 网 中 所 使 
用 的 各 种 以 太 网 协议 束 是 采用 这 种 服务 的 ， 因 为 以 太 网 中 的 数据 链 路 
性 能 非常 好 ， 数 据 可 靠 传 输 有 保障 。 在 以 太 网 中 的 数据 链 路 始终 是 存 
在 的 ， 不 用 夯 外 建立 ， 在 以 太 网 中 进行 数据 传输 时 接收 端 也 不 用 对 接 
收 到 的 每 一 帧 进行 确认 。 


2. 数 据 链 路 管理 


LLC 了 于 层 的 链 路 管理 功能 主要 是 针对 前 面 所 介绍 的 有 确认 的 面向 
连接 服务 类 型 (主要 应 用 于 广域网 中 ) 。 它 包括 三 个 主要 阶段 ， 链 路 


建立 、 链 路 保持 、 链 路 释放 。 


在 这 种 数据 链 路 层 服 务 中 ， 链 路 两 端的 节点 要 进行 通信 前 ， 发 送 
端的 数据 链 路 层 必须 先 确 认 对 方 已 处 于 束 绪 状态 ， 并 交换 一 些 必 要 的 
言 居 以 对 帧 序号 进行 初始 化 ， 然 后 双方 才能 建立 连接， 在 传输 过 程 中 
为 个 数据 连接 是 要 持续 你 持 的 ， 如 来 出 现 差错 ， 需 要 重新 初始 化 ， 重 
新 目 动 建立 连接 。 传 输 完 毕 后 则 要 释放 所 占用 的 数据 连接 ， 以 供 其 他 
通信 所 用 。 


数据 连 路 层 的 这 种 链 路 连接 的 建立 、 维 持 和 释放 过 程 束 十 数据 链 
路 层 的 链 路 管理 功能 。 在 多 个 站 点 共享 同一 物理 信道 的 情况 下 (例如 
在 局 域 网 中 ) ， 如 何在 要 求 通 信 的 站 点 间 分 配 和 管理 信道 也 属于 数据 
链 路 层 管理 的 范畴 。 


5.2.2 ”数据 帧 封装 和 透明 传输 


我 们 知道 数据 链 路 层 位 于 物理 层 和 网 络 层 之 间 。 在 发 送 端 ， 数 据 
链 路 层 是 接收 来 目 网 络 层 的 数据 分 组 ， 而 在 接收 痛 它 是 接收 来 目 物理 
层 的 比特 流 ， 所 以 数据 链 路 层 的 成 帧 功能 束 包 含 两 方面 的 含义 : 一 是 
将 来 目 网 络 层 的 数据 分 组 封 朔 成 数据 帧 ， 二 十 将 来 目 物理 层 的 一 个 个 
比特 流 组 装 成 数据 帧 。 因 为 帧 封装 将 物理 层 比特 流 组 装 成 帧 时 ， 称 
为 帧 同步 ;通常 是 与 透明 传输 一 起 考虑 并 实现 的 ， 所 以 在 此 一 并 介 
绍 。 不 过 本 节 仅 介绍 其 基本 原理 ， 在 本 章 后 面 还 会 结合 具体 的 数据 链 
路 层 协议 详细 介绍 这 些 帧 封 攻 和 透明 传输 原理 。 


1. 数 据 包 的 帧 封装 原理 


通过 前 面 的 学 习 我 们 束 已 经 知道 ， 网 络 层 传 输 的 包 (packet， 叉 称 
分 组 ) ， 在 数据 链 路 层 中 传输 的 是 “ 帧 ”(\frame) 。 数 据 包 到 达 数 据 链 
路 层 后 加 上 数据 链 路 层 的 协议 头 和 协议 尾 就 构成 了 一 个 数据 帧 。 在 每 
个 帆 的 前 部 加 上 一 个 帧 类 部 ， 在 帧 的 结尾 处 加 上 一 个 帧 尾部 ， 把 网 络 
层 的 数据 包 作为 帆 的 数据 部 分 ， 避 3 构成 了 一 个 完整 帜 。 帆 尖 和 帕 尾 下 
苹 作 为 帧 的 起 始 和 结束 标志 ， 也 束 是 帆 边 腹 ， 如 图 5-6 所 示 。 


网 络 层 
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图 5-6 网 络 层 数据 包 封 装 成 帧 的 示意 图 


由 数据 包 封 装 成 的 数据 帧 其 大 小 是 受 对 应 的 数据 链 路 层 协议 的 
MTU (最 大 传输 单元 ) 限制 的 ， 如 以 太 网 数据 链 路 层 封装 网 络 层 IP 包 
的 MTU 值 为 1500 字 《这 是 指 帧 中 数据 部 分 ， 也 就 是 来 自 网 络 层 整个 
数据 分 组 ， 最 大 不 能 超过 1500 字 下， 但 不 包括 帧 头 和 帧 尾部 分 ) 。 同 
时 ， 帧 还 有 最 小 大 小 限制 ， 如 以 太 网 帧 中 封装 的 IP 包 最 小 值 为 46 字 
他， 如果 封 装 的 卫 包 小 于 最 小 帧 要 求 时 ， 就 要 用 一 些 特 殊 字 符 进 行 填 
充 ， 以 满足 对 应 链 路 中 传输 最 小 帧 的 限制 。 


2. 比 特 流 的 帧 组 小 及 透明 传输 原理 


在 发 送 端 数据 链 路 层 中 的 帆 到 达 物 理 层 后 束 会 以 比特 位 为 单位 进 
行 传输 ， 而 不 是 以 巾 为 单位 进行 传输 。 尽 管 在 并 行 传输 方式 中 ， 可 以 
一 次 传输 一 个 或 多 个 字 节 ， 但 每 条 线路 中 的 传输 单位 还 是 比特 位 。 发 
送 闹 以 比 符 位 方式 一 位 位 地 传输 到 接收 器 的 物理 层 ， 然 后 接收 端的 物 
理 层 把 比 竺 访问 数据 链 路 层 传输 ， 到 达 后 又 要 将 比特 流 封闭 成 效 据 
蚌 ， 这 束 生 数据 链 路 层 的 帆 组 疤 方 式 了 ， 其 实 也 束 旦 我 们 前 面 捉 到 的 
须 同 步 问 题 。 帆 同 步 的 目的 整 古 要 使 接收 端的 数据 链 路 层 对 从 物理 层 
传输 而 来 的 一 串 串 比特 流 以 幅 为 单位 进行 区 分 。 


本 万 移 商 单 介绍 以 下 几 种 音 用 的 帧 同步 方法 的 基本 同步 原理 : 字 
斑 计 数 法 、 字 符 填 充 的 首尾 定 弄 符 法 、 比 特 填 充 的 首尾 定 弄 符 法 、 违 
法 编码 法 。 本 章 的 后 面 在 介绍 具体 的 数据 链 路 层 协议 时 还 将 具体 介绍 
它们 所 采用 的 同步 方法 。 


(1) 字 节 计数 法 


这 是 一 种 以 一 个 特殊 子 符 代表 一 个 帆 的 起 始 ， 并 以 一 个 专门 的 子 
段 来 标识 当前 帧 内 字 太 数 的 帧 同步 方法 。 接 收 端 可 以 通过 对 该 符 殊 子 
符 的 识别 从 比特 流 中 区 分 出 每 个 蚌 的 起 始 ， 并 从 专门 字段 中 获知 每 个 
帧 后 面 跟随 的 “数据 ”(Data) 字段 的 字 市 数 ， 从 而 可 确定 出 每 个 帧 的 结 
束 位 置 。 


这 种 面 问 字 世 计数 的 同步 规程 的 典型 实例 是 DEC 公司 的 DDCMP 
(Digital Data Communications Message Protocol， 数 字数 据 通信 报 协 
议 ) 。 在 DDCMP 协 议 通信 中 ， 数 据 是 在 源 站 点 与 从 站 点 之 间 以 编号 的 
数据 消息 的 形式 进行 交换 的 ， 而 从 站 点 是 以 未 编号 的 响应 和 控制 消息 
的 形式 向 主 站 点 返回 的 。 下 面 看 看 在 这 个 协议 的 数据 帧 中 如 何 实现 帧 

同步 ， 或 者 是 如 何 成 帧 的 : 


在 DDCMP 协 议 帧 格式 (如 图 5-7 所 示 ) 中 ，SOH 字 段 是 一 个 帧 的 
帧 头 开 始 部 分 ， 有 其 固定 的 值 (十 进 制 为 129， 八 进 制 值 为 201， 十 六 
进 制 值 为 81) ， 就 相当 于 一 个 帧 开始 的 特殊 字符 ;在 NUM 字 段 中 为 每 
个 数据 帧 分 配 一 个 编号 ， 从 “1 开始 ， 并 以 “1? 为 增 量 进行 递增 ， 最 大 值 
为 256 (也 就 是 模 为 256) ， 以 确保 在 从 站 点 中 的 正确 消息 序列 ， 同 时 
在 COUNT 字 段 中 指出 本 数据 帧 中 DATA 字 段 的 大 小 ， 这 些 都 是 用 来 进 
行 帧 同步 的 。 
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图 5-7 DDCMP 帧 格式 


(2) 字符 填充 的 首尾 定 界 符 法 


该 同步 方法 是 用 一 些 特定 的 控制 字符 来 是 办 一 个 帧 的 起 始 与 结 
束 ， 如 IBM 的 BSC 协 议 在 每 个 数据 块 的 尖 部 用 一 个 或 多 个 同步 子 


符 “SYN" 来 标记 数据 块 的 开始 ;尾部 用 字符 “ETX? 来 标记 数据 决 的 结 
束 。 图 5-8 所 示 的 是 要 传输 一 个 <ADFGJ" 的 字符 串 ， 在 帧 的 头 部 加 上 了 
两 个 SYN 控 制 字 符 ， 用 于 标识 该 帧 的 开始 ， 在 结束 位 置 加 了 ETX 控 制 
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字符 ， 用 于 标识 该 帧 的 结束 。 


这 是 帧 起 始 标志 字符 


图 5-8 


> i 这 是 帧 结束 
这 是 要 传输 的 字符 标志 字符 


字符 填充 的 首尾 定 界 符 帧 同步 访 法 应 用 示例 


另外 ， 为 了 不 使 数据 信息 中 与 以 上 特定 字符 相同 的 字符 被 误 判 为 
帆 的 首尾 定 界 符 ， 可 以 在 这 种 数据 幅 的 帧 头 填 充 一 个 转 义 控制 字符 
(Data Link Escape-Start of TeXt, DLE) 


， 这 吏 属 于 “透明 传输 ”的 范围 
了 ， 这 部 分 内 容 将 在 本 章 后 面 介绍 具体 的 数据 链 路 层 协议 时 介绍 。 


(3) 比特 填充 的 首尾 定 界 符 法 


该 帆 同 步 方 法 是 通过 在 帧 头 和 帧 尾 各 插入 一 个 特定 的 比特 串 (如 
01111110) 来 标识 一 个 数据 帧 的 起 始 与 结束 ， 这 个 帧 涉 、 帧 尾 特 定 比特 


串 称 为 帧 标志 符 。 如 传输 的 比特 流 为 1001110101， 组 雄 成 帧 后 惑 是 
Qllllli0Q100111010101111110 


O 〇 


而 为 了 透明 传输 ， 也 就 是 为 了 避免 在 信息 位 中 出 现 的 与 帧 起 始 和 
结束 标志 符 相 似 的 比特 串 时 被 误 判 为 帧 的 首 、 尾 标志 ， 采 用 了 比特 填 
充 的 方法 。 比 如 上 面 采用 的 特定 模式 为 “<01111110”"， 则 对 信息 位 中 的 任 
何 连 续 出 现 的 5 个 “1” (因为 帧 标志 符 中 是 有 5 个 连续 “1”) ， 发 送 端 自动 
在 其 后 插入 一 个 “0”。 如 要 传输 的 数据 帧 为 “<0110111111011111001”( 因 
为 其 中 有 5 个 连续 的 “1”， 很 可 能 被 误 认 为 是 帧 首 、 尾 标志 ) ， 采 用 比 


等 填充 后 ， 实 际 传送 的 是 
OT11111001101111101011111000101111110 注意， 前、 后 面 两 


个 “01111110” 是 帧 首 、 尾 标志 符 ; 。 男 外 ， 因 为 在 原 信息 中 ， 有 一 段 比 
符 流 与 帧 标志 答 类 似 ， 为 了 与 用 于 标识 帧 尖 和 巾 频 尾 的 特定 模式 字符 
区 别 ， 在 有 5 个 连续 “1” 的 比特 位 后 面 加 插入 一 个 “0” (斜体 “0”) 。 而 接 
受 方 在 收 到 上 壕 最 终 数据 后 进行 发 送 并 的 逆 操 作 ， 目 先 去 挥 两 端的 特 
定 模式 字符 ， 然 后 在 每 收 到 连续 5 个 “1 的 比特 位 后 自动 删 去 其 后 所 跟 
的 “0”， 以 此 恢复 原始 信息 。 


比特 填充 帧 同步 方式 很 容易 由 硬件 来 实现 ， 性 能 优 于 字符 填充 方 
式 。 所 有 面向 比特 的 同步 控制 协议 均 采用 统一 的 帧 格式 ， 不 论 是 数 
据 ， 还 是 单独 的 控制 信息 均 以 帧 为 单位 传送 ， 其 典型 代表 是 ISO 的 
HDLC 协 议 ， 在 它 的 首尾 均 有 标志 字段 \Flag，8 位 ， 即 0111110) ， 具 
体 将 在 本 章 后 面 介绍 。 


(4) 违法 编码 法 


该 帧 同步 方法 是 在 物理 层 采 用 特定 的 比特 编码 方法 时 采用 。 例 
如 ， 曼 彻 斯 特 编码 方法 ， 将 数据 “1” 编 码 成 “高 - 低 ” 电 平 对 (在 半 个 码 元 
处 跳 变 ， 下 同 ， 具 体 参见 4.4.2 厄 ) ， 将 数据 “0 编码 成 “ 低 -高 ”" 电 平 对 。 
而 高 -高 电 平 对 和 低 - 低 电 平 对 在 数据 比特 中 是 违法 的 ， 因 此 可 以 借用 这 
些 违 法 编码 序列 来 定 界 帧 的 起 始 与 终止 。 违 法 编码 法 不 需要 任何 填充 
技术 ， 便 能 实现 数据 的 透明 性 ， 但 它 只 适用 于 采用 元 余 编码 的 特殊 编 
码 环境 。 


5.2.3 ”差错 控制 


说 明 ”因数 据 链 路 层 中 的 差错 控制 功能 涉及 比较 多 且 比 较 复 杂 的 
技术 ， 所 以 在 此 仪 进行 综合 介绍 ， 具 体 的 差错 控制 技术 将 在 本 章 后 面 


ds 


在 上 市 介绍 的 “成 巅 * 功 能 解决 了 帆 同 步 问 题 ， 也 就 是 接收 端 可 以 
区 分 每 个 数据 帧 的 起 始 和 结束 了 ， 但 是 还 没有 解决 数据 正确 传输 的 两 
方面 问题 : 一 是 如 果 有 帧 出 现 了 错误 怎么 办 ? 二 是 如 果 有 帧 丢失 了 怎 
么 办 ? 这 都 古 数 据 链 路 层 确 保 疝 网 络 层 提供 可 靠 数 据 传 输 服务 要 解决 
的 问题 ， 也 就 是 数据 链 路 层 的 差错 控制 功能 。 


要 实现 差错 控制 功能 ， 束 必须 具备 两 种 能 力 :一 具备 发 现 差 错 的 
能 力 ， 二 十 具备 纠正 错误 的 能 力 。 殉 像 我 们 要 发 行 一 个 “问题 "小 孩 一 
样 ， 你 首先 要 知道 他 的 “问题 ”在 哪里 ， 也 束 是 存在 问题 的 根源 在 哪 
里 ， 然 后 才能 采取 适当 的 方法 纠正 这 个 “问题 ”小孩 身上 的 问题 。 


1. 差 错 检 测 


在 数据 链 路 层 检测 数据 传输 错误 的 方法 一 般 是 通过 对 差错 编码 进 
行 校 验 来 实现 ， 汕 见 的 校 验 方法 有 奇 偶 校 答 码 (Parity Check Code， 


PCC) 、 循 环 见 余 校 验 (Cyclic Redundancy Check，CRC) 两 种 。 它 
们 都 统称 为 检 错 人 码 (error-detecting code) 。 


奇偶 校 验 码 是 一 种 校 验 代码 传输 正确 性 的 方法 ， 是 根据 被 传输 的 
一 组 二 进 制 代码 的 数位 中 “1 的 个 数 是 奇数 或 偶数 来 进行 校 星 的 。 采 
用 “1” 的 奇数 个 校 验 的 方法 称 为 奇 校 验 ， 反 之 称 为 偶 校 验 ， 但 采用 何 种 
校 验 是 事先 确定 好 的 。 具 体 做 法 古 在 传输 的 二 进 制 代码 最 后 专门 设置 
一 个 奇偶 校 验 位 ， 用 它 使 这 组 代码 中 1 的 个 数 为 奇数 或 偶数 〈 具 体 是 偶 
数 还 是 奇数 ， 要 视 所 采用 的 是 偶 校 验 还 是 奇 校 验 )  ， 然 后 再 在 接收 闪 
进行 校 验 ， 看 里 面 的 “1” 的 个 数 是 否 仍 与 原来 一 样 的 奇数 或 偶数 ， 来 确 
定数 据 传输 的 正确 性 。 


循环 元 余 校 验 旦 一 种 根据 传输 或 保存 的 数据 而 产生 固定 位 数 校 验 
码 的 方法 ， 主 要 用 来 检测 或 校 验 数据 传输 或 者 保存 后 可 能 出 现 的 错 
误 。 生 成 的 数字 在 传输 或 者 储存 之 前 计算 出 来 并 且 附 加 到 数据 后 面 ， 
然后 接收 端 进行 检验 确定 数据 是 否 发 生变 化 。 


有 关 以 上 这 两 种 差错 检测 方法 在 本 章 后 面 有 专门 的 介绍 。 
2. 甜 销 纠 正 


在 差错 纠正 方面 ， 数 据 链 路 层 针对 不 同 的 传输 类 型 采取 了 不 同 的 
纠 错 方法 。 对 于 面 癌 字符 的 异步 传输 〈 如 键盘 与 主机 的 通信 、AIM 传 
输 协 议 等 ) 一 般 是 采用 “反馈 检测 ”的 方法 来 进行 纠 错 。 束 是 在 接收 端 


收 完 一 帧 数据 后 ， 回 发 送 端 发 送 回 所 接收 到 的 完整 数据 帧 ， 由 发 送 端 
通过 与 原始 发 送 的 帧 进行 比较 来 判断 接收 端 和 否 正 确 接收 了 对 应 帆 。 
如 采 判 断定 出 了 错 ， 则 发 送 问 癌 接收 端 发 送 一 个 DEL 字符 及 相应 的 帆 
信息 ， 提 示 接 收 问 删除 对 应 的 帜 ， 然 后 重 发 该 帧 ， 否 则 表示 接收 端 已 
正确 接收 了 对 应 的 巾 ， 不 重 发 对 应 的 帜 。 但 对 于 在 传输 过 程 中 完全 丢 
失 的 数据 吏 不 能 采用 这 种 纠 错 方法 了 ， 因 为 接收 端 根 本 没有 收 到 这 帧 
数据 ， 所 以 也 区 不 会 癌 发 送 端 发 回 反 锯 信 息 ， 发 送 端 目 然 吏 不 能 确认 
接收 病 是 否 正 确 接收 了 对 应 的 帧 。 


为 了 解决 这 个 问题 ， 通 常 在 数据 发 送 时 引入 计时 器 (Timer) 来 限 
定 接收 端 发 回 反 饶 信 息 的 时 间 间 隔 。 当 发 送 端 发 送 一 帆 数 据 的 同时 局 
动 计时 右 ， 寿 在 限定 时 间 间 隔 内 没有 收 到 接收 问 的 反馈 信息 ， 即 计时 
器 超时 (Timeout) ， 则 可 认为 传 的 对 应 帧 已 出 错 ， 或 丢失 ， 继 而 发 送 
端 知道 要 重新 发 送 对 应 的 数据 帧 。 同 时 ， 为 了 避免 同一 帧 数据 可 能 被 
多 次 重复 发 送 ，3 引 发 接收 器 多 次 收 到 同一 帧 并 将 其 递交 给 网 络 层 的 危 
仿 ， 采 用 对 发 送 的 巾 进 行 编号 的 方法 ， 即 同一 个 巾 的 编号 是 一 样 的 ， 
从 而 使 接收 问 能 从 帧 编号 来 区 分 是 新 发 送 来 的 帜 ， 还 古 已 经 接收 但 又 
重新 发 送 来 的 蚌 ， 以 此 来 确定 要 不 要 将 重新 接收 到 的 帧 递交 给 网 络 
人 


由 于 在 “反馈 检测 法 ”中 一 帆 数 据 会 在 信道 中 至 少 往返 传输 两 次 ， 
传输 效率 低 ， 所 以 一 般 不 采用 这 种 差错 控制 方法 ， 而 是 采用 一 种 称 


为 “自动 重 发 请 求 ”(ARQ 法 ) 的 方法 。 实 现 原理 就 是 先 让 发 送 端 将 要 
发 送 的 数据 帧 附加 一 定 的 元 余 检 和 错 码 (如 前 面 介绍 的 PCC、CRC 码 ) 
一 起 发 送 ， 接 收 端 则 根据 检 错 码 对 数据 帧 进行 错误 检测 ， 若 发 现 错 
误 ， 就 返回 请 求 重 发 的 响应 〈 不 用 返回 全 部 的 帧 ) ， 发 送 端 收 到 请 求 
重 发 的 响应 后 ， 便 重新 传送 该 数据 帧 。 


另外 ， 还 有 一 些 编码 本 身 具有 自动 纠正 错误 的 能 力 ， 称 为 “ 纠 错 
码 ” (Error-correcting Code) ， 在 数据 链 路 层 中 常用 的 如 海 明 码 


(Hamming Code) 。 


以 上 郑 错 控制 方法 都 将 在 本 章 后 面具 体 介绍 。 


5.2.4 流量 控制 


“流量 控制 * 包 括 两 方面 的 含义 : 一 是 发 送 端的 数据 发 送 速度 与 接 
收 疾 的 数据 接收 速度 要 匹配 ， 人 否则 接收 端 来 不 及 接收 殉 会 造成 数据 在 
传输 过 程 中 的 丢失 。 这 个 很 好 理解 ， 比 如 几 个 人 站 成 一 排 传递 货物 
时 ， 如 果 中 间 有 个 人 速度 比较 慢 ， 而 上 面 的 人 不 断 传 来 货物 ， 肯 定 束 
会 把 来 不 及 接收 的 货物 放 在 地 上 〈 不 进入 正 第 的 传递 之 中 ) 。 二 是 发 
送 端的 数据 发 送 速度 要 与 线路 上 的 承载 速率 《与 线路 信道 带宽 有 关 ) 
相 匹 配 ， 人 否则 也 会 造成 数据 在 传输 过 程 中 的 丢失 。 这 个 也 很 好 理解 ， 
束 像 一 条 小 河 ， 上 游 来 的 水 量 很 大 ， 超 过 了 小 河 所 能 承载 的 能 力 ， 这 
时 上 游 来 的 水 肯定 束 不 会 有 原来 那么 大 的 流速 (形成 速率 瓶 贷 ， ，， 甚 
至 可 能 会 漫 过 小 河 河 韦 而 流 到 外 面 。 


注意 ”流量 控制 并 不 是 数据 链 路 层 所 特有 的 功能 ， 许 多 高 层 协议 
中 也 提供 流量 控 功 能 ， 只 不 过 流量 控制 的 对 象 不 同 而 已 。 比 如 ， 对 于 
数据 链 路 层 来 说 控制 的 是 相 邻 两 节点 之 间 数 据 链 路 上 的 流量 ， 而 对 于 
传输 层 来 说 控制 的 是 从 源 到 最 终 目 的 端 之 间 的 流量 。 


在 数据 通信 中 ， 由 于 通信 双方 各 目 使 用 的 设备 工作 速率 和 缓冲 存 
储 的 至 间 的 差异 ， 可 能 出 现 发 送 端 发 送 能 力 大 于 接收 闪 接 收 能 力 的 现 
象 ， 如 大 此 时 不 对 发 送 端的 发 送 速 率 作 适当 的 限制 ， 在 接收 端 前 面 来 


不 及 接收 的 帧 将 被 后 面 不 断 发 送 来 的 帧 所 “淹没 "， 从 而 造成 帆 的 丢 
失 。 由 此 可 见 ， 数 据 链 路 层 上 的 “流量 控制 ”功能 实际 上 古 对 发 送 端 数 
据 传 输 速 率 的 控制 ， 使 其 数据 发 送 速 率 不 超过 接收 端 所 能 承受 的 数据 
接收 能 力 。 考 虑 到 在 接收 端 还 需要 对 来 目 物理 层 的 比特 流 进行 一 系列 
的 处 理 ， 如 帧 封装 ， 向 发 送 端 发 送 返 回 确认 帧 等 ， 所 以 通常 是 要 使 发 
送 疾 的 发 送 速率 略 小 于 接收 闯 的 数据 处 理 能 


在 数据 链 路 层 中 进行 流量 控制 的 方案 有 了 两 种 : 一 是 基于 反馈 的 流 
量 控制 方案 ， 二 是 基于 速率 的 流量 欣 制 方案 。 


1. 基 于 反馈 的 流量 控制 方案 


“基于 反馈 的 流量 控制 方案 ” 束 古 接收 器 在 接收 到 一 个 数据 帧 后 ， 
要 同 发 送 瘦 发 送 一 个 确认 帆 ， 表 示 发 送 端 可 以 继续 同 它 发 送 数 据 了 。 
这 种 方案 也 称 “ 停 -等 ”方案 (也 就 是 将 在 5.3.4 节 介绍 的 “ 空 帮 重 发 请 
求 "方案 ) ， 就 是 发 送 端 在 发 送 一 帧 数据 后 必须 等 得 接收 问 返 回 确认 阿 
应 消 轧 ， 然 后 才能 发 送 下 一 数据 帧 。 接 收 站 十 通过 检查 帧 的 校 验 序列 
(FCS) ， 无 错 则 发 送 确认 巾 ， 否 则 不 发 送 返 回 消 息 ， 表 示 该 帆 已 出 
错 ， 要 求 重 发 。 


其 实 这 也 就 是 利用 上 市 介绍 的 差错 控制 方案 。 但 这 里 存在 一 个 问 
题 ， 束 是 在 数据 帧 或 确认 帆 丢 失 时 ， 双 方 会 无 休 目 等待。 解决 这 一 问 
题 的 方法 是 发 送 后 使 用 定时 人 右 ， 在 发 送 端 发 送 一 帆 数 据 时 会 局 动 这 个 


定时 右 ， 要 求 接收 端 必须 在 这 个 时 间 内 返回 确认 帧 ， 否 则 束 认 为 这 个 
数据 帧 已 丢失 ， 重 发 该 数据 巾 。 当 然 ， 与 上 市 介绍 的 差错 控制 方案 时 
提 到 的 一 样 ， 这 也 可 能 造成 接收 端 接收 到 多 个 一 样 的 数据 帧 ， 解 决 这 
一 问题 的 方法 整 古 给 每 个 巾 加 上 一 个 编号 ， 这 样 编 号 一 样 的 帧 接收 端 
只 需 接 收 其 中 一 个 即 可 ， 其 他 的 丢弃 。 


由 此 可 以 看 出 ,，“ 集 -等 ”方案 其 实 谍 古 直 接 利 用 了 上 市 介 绍 的 纠 错 
方案 ， 这 里 提 到 的 几 种 措施 可 以 说 是 一 环 扣 一 环 ， 最 终 可 以 既 确 你 数 
据 的 可 靠 传 输 〈 也 就 是 “差错 控制 "功能 ) ， 又 有 效 地 控制 了 双方 通信 


的 流量 (也 就 是 “流量 控制 ”功能 ) 。 


2. 基 于 速率 的 流量 控制 方案 


“基于 速率 的 流量 控制 方案 ” 征 基 于 窗口 滑动 机 制 的 速率 控制 方 
案 ， 它 规定 发 送 端 一 次 可 以 发 送 多 少 个 数据 帧 ， 限 制 了 发 送 端的 数据 
传输 速率 ， 而 无 须 接收 瑞 发 回 确认 帆 。 这 种 机 制 等 在 本 和 章 后 面 也 有 专 
门 介绍 。 其 实 它 与 第 10 章 要 介绍 的 传输 层 流 量 控制 方案 是 极其 类 似 
的 ， 不 同 的 只 古 数 据 链 路 层 的 流量 控制 是 针对 链 路 两 端的 点 对 点 控 
制 ， 而 传输 层 则 是 直接 针对 通信 双方 的 端 到 端 系统 。 


5.3 ”过 销 欣 制 方案 


前 面 已 讽 到 ， 数 据 链 路 层 的 老 错 控制 功能 分 为 老 错 检测 功能 和 差 
错 纠正 功能 。 在 差错 检测 方面 通常 在 数据 帧 中 加 上 一 些 具有 检 和 错 功 能 
的 匈 余 代码 ( 称 为 检 错 码 ，Error-detecting Code) ， 然 后 根据 这 些 见 余 
代码 所 表达 的 信息 ， 以 及 接收 问 对 数据 帧 的 奇偶 性 重新 计算 的 结果 束 
可 以 发 现 数据 帧 在 传输 过 程 中 是 否 出 现 差 错 。 如 前 面 说 到 的 PCC ( 奇 
偶 校 验 码 ) 、CRC (循环 见 余 校 验 ) 都 属于 检 错 码 。 但 它们 均 不 具有 
目 动 纠 错 功能 ， 不 能 确定 是 哪 一 个 或 哪 一 些 位 出 错 了 ， 也 不 能 纠正 这 
些 差错 ， 通 常 也 是 与 纠 错 方案 中 的 自动 请 求 重 发 法 (ARQ 法 ) 结合 起 


在 差错 纠正 方面 主要 有 反馈 检测 法 和 自动 重 发 请 求法 两 种 (自动 
重 发 请 求法 中 又 分 为 几 种 ， 如 空闲 重 发 请 求法 ， 连 续 重 发 请 求法 
等 ) 。 也 有 一 些 具 有 上 自动 纠 错 功能 的 编码 ， 称 为 纠 错 码 (Error- 
correcting Code) ， 又 称 前 向 纠 错 码 (Forward Error Correction) ， 如 
海 明 码 (Hamming Code) 。 这 些 方案 都 将 在 下 面 各 小 节 中 有 具体 介绍 。 


5.3.1 奇偶 校 验 码 检 错 方案 


奇偶 校 验 码 (PCC) 是 奇 校 验 码 和 偶 校 验 码 的 统称 ， 征 一 种 有 效 
仿 测 单个 错误 的 检 错 方法 。 它 的 基本 校 验 思 想 古 在 原 信息 代码 的 最 后 
添加 一 位 用 于 奇 校 验 或 偶 校 验 的 代码 ， 这 样 最 终 的 帧 代码 是 由 n-1 位 信 
元 码 和 1 位 校 验 码 组 成 ， 可 以 表示 成 为 m，n-1) 。 加 上 校 验 码 的 最 终 
目的 就 是 要 让 传输 的 帧 中 “1 的 个 数 固定 为 奇数 (采用 奇 校 验 时 ) 或 偶 
数 (采用 侦 校 验 时 ) ， 然 后 通过 接收 端 对 接收 到 的 帧 中 “1” 的 个 数 的 实 
际 计算 结果 与 所 选 定 的 校 验 方式 进行 比较 ， 殊 可 以 得 出 对 应 帧 数据 在 
传输 过 程 中 十 否 出 错 了 。 如 采 是 奇 校 验 码 ， 在 附加 上 一 个 校 验 码 以 
后 ， 码 长 为 的 码 中 “1” 的 个 数 为 奇数 ， 如 果 是 偶 校 验 码 ， 则 在 附加 上 
一 个 校 验 码 以 后 ， 码 长 为 n 的 码 中 “1” 的 个 数 为 偶数 (0 个 “1” 也 看 成 是 
偶数 个 “1”) 。 奇 偶 校 验方 法 可 以 以 通过 电路 来 实现 ， 也 可 以 通过 软件 
来 实现 ， 在 此 我 们 只 要 知道 它 校 验 的 原理 即 可 。 


下 面 打 个 很 简单 的 比喻 来 说 明 PCC 的 校 验 原理 。 现 假设 一 学 校 要 
组 织 各 班 学 生 参 加 一 次 长 跑 运动 ， 同 时 有 儿 和 名 外 地 学 生 想 参加 长 跑 运 
动 ， 需 在 每 班 插入 一 个 外 地 学 生 ， 但 插入 的 学 生性 别 不 能 随意 ， 最 终 
要 求 插入 外 地 学 生 后 各 班 的 女 学 生 数 必须 为 偶数 (相当 于 采用 侦 校 验 
方式 ， 当 然 也 可 以 要 求 必 须 为 柯 数 ， 大 为 奇数 ， 则 此 时 为 奇 校 验 方 
式 ) ， 这 样 就 可 确定 每 班 插入 的 这 位 外 地 学 生 的 性 别 了 。 如 果 长 跑 后 
各 班 清点 人 数 时 ， 发 现 有 些 班 的 女生 数量 不 是 原来 规定 的 偶数 〈 或 奇 
数 ) ， 则 证 明 这 些 班 的 学 生 在 长 跑 过 程 中 走 乱 了 (相当 于 数据 在 传输 


途中 出 现 了 差错 ) 或 者 有 学 生 掉队 (相当 于 数据 在 传输 途中 丢失 了 ) 
了 。 这 束 是 我 们 这 里 所 说 的 奇偶 校 验 原 理 。 


我 们 知道 ASCII 字 符 是 8 位 编码 ， 其 中 高 7 位 是 信息 代码 ， 最 后 1 位 
就 是 奇偶 校 验 位 。 如 现在 传输 的 是 ASCII 字 符 ， 如 果 采 用 奇 校 验 ， 则 
每 个 ASCII 子 符 代 码 中 “1” 的 个 数 均 必须 为 奇数 个 ， 如 果 发 现 某 个 字符 
中 “1 的 个 数 是 偶数 ， 则 这 个 ASCII 字 符 在 传输 过 程 中 肯定 出 错 了 ; 同 
理 ， 如 果 采 用 的 是 偶 校 验 ， 则 每 个 ASCIH 字 符 代码 中 “1” 的 个 数 均 必须 
为 偶数 个 ， 如 有 果 发 现 某 个 字符 中 “1 的 个 数 是 柯 数 ， 则 这 个 ASCII 字 符 
在 传输 过 程 中 也 肯定 出 错 了 。 其 他 采用 奇偶 校 验 方式 的 数据 的 校 验 原 
理 也 是 一 样 的 。 


假设 现在 要 传输 一 个 ASCII 字 符 ， 它 的 高 7 位 代码 为 1011010， 现 
在 要 采用 奇 校 验方 法 ， 则 该 字符 的 校 验 码 为 "1”， 整 个 ASCII 字 符 代 人 码 
就 是 1011010 1， 因 为 该 字符 中 高 7 位 信息 代码 中 的 “1 的 个 数 是 偶数 个 

(4 个 ) ， 必 须 再 加 一 个 “1? 才 能 为 奇数 ; 同 理 ， 如 要 采用 偶 校 验方 
法 ， 则 该 字符 的 校 验 码 为 “0”"， 整 个 ASCII 字 符 代 码 就 是 1011010 0， 
为 该 字符 中 高 7 位 信息 代码 中 的 “1 的 个 数 已 是 偶数 个 (4 个 ) ， 所 以 最 
后 一 位 中 不 能 再 是 “1”， 只 能 为 “0”。 


这 里 要 注意 ， 无 论 古 采 用 奇 校 验 ， 还 十 侦 校 验 ， 每 一 信息 的 校 验 
位 是 “0” 还 是 “1” 都 足 不 固定 的 ， 要 视 信息 前 n-1 位 中 “1” 的 具体 个 数 而 
定 。 如 末末 用 的 是 “ 奇 校 验 ”， 则 要 求 所 传输 的 n 位 信息 中 “1” 的 忌 个 数 


必须 为 奇数 : 如果 前 面 n-1 位 中 “1” 的 个 数 已 是 奇数 ， 则 第 hn 位 的 校 验 码 
位 一 定 是 “0”"， 只 有 这 样 才能 确保 整个 n 位 信息 中 “1” 的 个 数 仍 为 奇数 ; 
如 果 前 面 n-1 位 中 “1” 的 个 数 古 偶数 ， 则 第 n 位 的 校 验 码 位 一 定 是 “1”， 
只 有 这 样 才能 确 你 整个 n 位 信息 中 “1” 的 个 数 为 奇数 。 


如 果 采 用 的 是 偶 校 验 ， 则 要 求 所 传输 的 n 位 信息 中 “1 的 总 个 数 必 
须 为 偶数 〈0 个 也 看 成 是 偶数 个 ) : 如 果 前 面 n-1 位 中 “1 的 个 数 是 奇 
数 ， 则 第 n 位 的 校 验 码 位 一 定 是 “1”， 只 有 这 样 才 能 确保 整个 n 位 信息 
中 “1” 的 个 数 为 偶数 ， 如 果 前 面 n-1 位 中 “1” 的 个 数 是 偶数 ， 则 第 n 位 的 
校 验 码 位 一 定 是 “0”"， 只 有 这 样 才能 确保 整个 n 位 信息 中 “1” 的 个 数 仍 为 


奇数 。 


另 一 个 要 注意 的 是 ， 奇 偶 校 验方 法 只 可 以 用 来 检查 单个 码 元 错 
误 ， 检 错 能 力 较 差 ， 所 以 一 般 只 用 于 本 号 误 人 码 率 较 低 的 环境 ， 如 用 于 
以 太 局 域 网 中 、 用 于 磁 副 的 数据 存储 中 等 。 如 现在 采用 的 是 奇 校 验 方 
法 ， 传 输 的 整个 8 位 ASCII 字 符 代 码 为 10100100 (最 低位 为 校 验 位 ) ， 
如 有 果 里 面前 7 位 信息 代码 有 一 位 出 现 了 差错 ， 由 原来 的 “0” 变 为 “1”， 或 
者 由 原来 的 “1” 变 为 <0”"， 都 会 改变 里 面 “1” 的 个 数 ， 最 终 导致 与 对 应 的 
奇 校 验方 法 不 一 致 ， 在 这 种 情况 下 PCC 能 判断 这 个 字符 传输 出 错 。 但 
是 如 果 里 面前 7 位 信息 代码 同时 有 2 位 或 多 位 出 现 了 差错 ， 最 终 的 结果 
可 能 会 使 字符 的 整个 8 位 代码 中 “1” 的 个 数 奇偶 性 不 变 ， 而 不 能 判断 这 
个 字符 传输 出 错 。 如 以 上 字符 代码 变 为 10001100， 结 果 “1” 的 个 数 仍 为 


奇数 个 (3 个 ) ， 但 实际 上 该 数据 已 不 是 原来 的 数据 了 。 这 就 为 什么 奇 
偶 校 验方 法 只 能 检测 出 单个 码 元 错误 的 原因 。 


作为 课 后 练习 ， 大 家 目 己 再 分 析 一 下 ， 如 采 所 传输 的 二 进 制 序列 
臣 11101100101， 现 要 采用 奇 校 验 ， 则 校 验 位 的 值 是 什么 ? 采用 侦 校 验 
呢 ? 


5.3.2 ”循环 元 余 和 核准 检 销 方 案 


上 节 介 绍 的 奇偶 校 验 码 (PCC) 只 能 校 验 一 位 错误 ， 本 节 要 介绍 
的 循环 见 余 校 验 码 (CRC) 的 检 错 能 力 更 强 ， 可 以 检 出 多 位 错误 。 
1.CRC 校 验 原 理 


CRC 校 验 原 理 看 起 来 比较 复杂 、 难 懂 ， 因 为 大 多 数 书 上 基本 上 都 
征 以 二 进 制 的 多 项 式 形式 来 说 明 的 。 其 实 其 原理 很 丛 单 ， 根 本 思想 融 
征 先 在 要 发 送 的 帆 后 面 附加 一 个 数 (这 个 数 束 是 用 来 校 验 的 校 验 码 ， 
但 要 注意 ， 这 里 的 数 也 是 二 进 制 序列 的 ， 下 同 ) ， 生 成 一 个 新 帧 发 送 
给 接收 问 。 当 然 ， 这 个 附加 的 数 不 是 随意 的 ， 它 要 使 所 生成 的 新 帧 能 
与 发 送 端 和 接收 端 共同 选 定 的 某 个 特定 数 整除 (注意 ， 这 里 不 是 直接 
采用 二 进 制 除法 ， 而 是 采用 一 种 称 为 模 2 除 法 的 方法 ) 。 到 达 接 收 端 
后 ， 再 把 接收 到 的 新 帧 除 以 (同样 采用 模 2 除 法 ， 这 个 选 定 的 除数 。 因 
为 在 发 送 闹 发 送 数 据 帧 之 前 束 已 附加 了 一 个 数 ， 做 了 去 余 处 理 (也 束 
己 经 能 整除 了 ) ， 所 以 结 采 应 该 没有 余数 。 如 采 有 余数 ， 则 表明 该 帆 
在 传输 过 程 中 出 现 了 差错 。 


说 明 ” 模 2 除法 与 算术 除法 类 似 ， 但 它 既 不 同上 位 借 位 ， 也 不 比较 
除数 和 被 除数 的 相同 位 数值 的 大 小 ， 只 以 相同 位 数 进行 相 除 。 模 2 加 法 
运算 为 : 1+1=0，0+1=1，0+0=0， 无 进位 ， 也 无 借 位 。 模 2 减法 运算 


为 : 1-1=0，0-1=1，1-0=1，0-0=0， 也 无 进位 ， 无 借 位 ， 相 当 于 二 进 制 
中 的 逻辑 异 或 运算 。 也 就 是 比较 后 ， 两 者 对 应 位 相同 则 结果 为 “0”， 不 
同 则 结果 为 “1”。 如 100101 除 以 1110， 结 果 得 到 商 为 11， 余 数 为 1， 如 图 
5-9a 图 所 示 。 再 如 11x11=101， 如 图 5-9b 图 所 示 。 


1 1 < 一 商 


1110 [100101 a 


1110 x 11 
1110 i 
1110 1] 
人数 101< 各 
a ) b ) 


图 5-9 “ 模 2 除 法 "和 “ 模 2 乘法 ”示例 
具体 来 说 ，CRC 校 验 的 实现 分 为 以 下 儿 个 步 又 : 
1) 先 选 择 (可 以 随机 选择 ， 也 可 按 标准 选择 ， 具 体 在 后 面 介绍 ) 
一 个 用 于 在 接收 并 进行 校 验 时 ， 对 接收 的 帧 进行 除法 运算 的 除数 〈 和 是 


二 进 制 比较 特 串 ， 通 单 是 以 多 项 方式 表示 ， 所 以 CRC 又 称 多 项 式 编 码 


方法 ， 这 个 多 项 式 又 称 生 成 多 项 式 ) 。 


2) 看 所 选 定 的 除数 二 进 制 位 数 (假设 为 k 位 ) ， 然 后 在 要 发 送 的 
数据 帧 (假设 为 m 位 后面 加 上 k-1 位 “0”"， 接 着 以 这 个 加 了 k-1 个 “0” 的 


新 帧 (一 共 是 m+k-1 位 ) 以 “ 模 2 除法 ”方式 除 以 上 面 这 个 除数 ， 所 得 到 
的 余数 (也 是 二 进 制 的 比特 串 ) 就 是 该 帧 的 CRC 校 验 码 ， 又 称 FCS ( 帧 
校 验 序列 ) 。 但 要 注意 的 是 ， 余 数 的 位 数 比 除数 位 数 只 能 少 一 位 ， 哪 
怕 前 面 位 是 0， 甚 至 是 全 为 0 〈 附 带好 整除 时 ) 也 都 不 能 省 略 。 


3) 再 把 这 个 校 验 码 附加 在 原 数 据 帧 〈 就 是 mm 位 的 帧 ， 注 意 不 是 在 
后 面 形 成 的 m+k-1 位 的 帧 后面， 构建 一 个 新 帧 发 送 到 接收 端 ， 最 后 在 
接收 咽 再 把 这 个 新 帧 以 “ 模 2 除 法 ”方式 除 以 前 面 选择 的 除数 ， 如 琳 没 有 
余数 ， 则 表明 该 帧 在 传输 过 程 中 没 出 错 ， 否 则 出 现 了 差错 。 


通过 以 上 介绍 ， 大 家 一 定 可 以 理解 CRC 校 验 的 原理 了 。 


从 上 面 可 以 看 出 ，CRC 校 验 中 有 两 个 关键 点 : 一 是 要 预先 确定 一 
个 发 送 端 和 接收 端 都 用 来 作为 除数 的 二 进 制 比特 串 (或 多 项 式 ) ; 二 
是 把 原始 帧 与 上 面 选 定 的 除 进 行 二 进 制 除法 和 运算， 计算 出 FCS。 前 者 可 
以 随机 选择 ， 也 可 按 国际 上 通行 的 标准 选择 ， 但 最 高 位 和 最 低位 必须 
均 为 "1”， 如 在 IBM 的 SDLC (同步 数据 链 路 控制 ， 规 程 中 使 用 CRC 一 一 
16 (也 就 是 这 个 除数 一 共 是 17 位 ) 生成 多 项 式 g(x)=x's +x 5 +x? +1 (对 
应 二 进 制 比特 串 为 11000000000000101) ; 而 在 ISO HDLC (高 级 数据 
链 路 控制 ) 规程 、ITU 的 SDLC、X.25、V.34、V.41、V.42 等 中 使 用 
CCITT 一 一 16 生 成 多 项 式 g(x)=x16 +x13 +X5 +1 《对 应 二 进 制 比特 串 为 
11000000000100001) 。 


2.CRC 校 验 码 的 计算 示例 


由 以 上 分 析 可 知 ， 除 数 是 随机 或 者 按 标准 先是 的 ， 所 以 CRC 校 验 
的 关键 是 如 何 求 出 余数 ， 也 就 是 校 验 码 (CRC 校 验 码 ) 。 


下 面 以 一 个 例子 来 具体 说 明 整 个 过 程 。 现 假设 选择 的 CRC 生 成 多 
项 式 为 G(X)=X4+X3 +1， 要 求 出 二 进 制 序列 10110011 的 CRC 校 验 码 。 
下 面 是 具体 的 计算 过 程 : 


1) 首先 把 生成 多 项 式 转 换 成 二 进 制 数 ， 由 G(X)=X4 +X3 +1 可 以 知 
道 ， 它 一 共 是 5 位 《总 位 数 等 于 最 高 位 的 需 次 加 1， 即 4+1=5) ， 然 后 根 
据 多 项 式 各 项 的 含义 〈 多 项 式 只 列 出 二 进 制 值 为 1 的 位 ， 也 就 是 这 个 二 
进 制 的 第 4 位 、 第 3 位 、 第 0 位 的 二 进 制 均 为 1， 其 他 位 为 0) 很 快 就 可 得 
到 它 的 二 进 制 比特 串 为 11001 。 


2) 因为 生成 多 项 式 的 位 数 为 5， 根 据 前 面 的 介绍 得 知 ，CRC 校 验 
码 的 位 数 为 4 〈 校 验 码 的 位 数 比 生成 多 项 式 的 位 数 少 1) 。 因 为 原 数据 
帧 10110011， 在 它 后 面 再 加 4 个 0， 得 到 101100110000， 然 后 把 这 个 数 
以 “ 模 2 除法 ”方式 除 以 生成 多 项 式 ， 得 到 的 结果 为 0100， 如 图 5-10 所 


示 。 注 意 参 考 前 面 介绍 的 “ 模 2 除法 ”运算 法 则 。 


11010100 


11001|101100110000 
11001| 


11110 


< 一 这 4 个 “0” 是 附加 上 去 的 


0100 < 一 余数 ， 因 不 够 要 求 的 4 位 ， 所 


图 5-10 ”CRC 校 验 码 计 算 示例 


3) 用 上 步 计 算得 到 的 CRC 校 验 奉 换 帧 101100110000 后 面 的 4 
个 “0”， 得 到 新 的 帧 101100110100。 再 把 这 个 新 帧 发 送 到 接收 端 。 


4) 当 以 上 新 帧 到 达 接 收 并 后 ， 接 收 端 会 把 这 个 新 帧 再 用 上 面 选 定 
的 除数 11001 以 “ 模 2 除 法 ”方式 去 除 ， 验 证 余数 是 否 为 0， 如 果 为 0， 则 证 
明 该 帆 数 据 在 传输 过 程 中 没有 出 现 震 错 ， 人 否则 出 现 了 老 错 。 


通过 以 上 对 CRC 校 验 原 理 的 天 析 和 CRC 校 验 码 计 算 示 例 的 介绍 ， 
大 家 应 该 对 这 种 看 似 很 复杂 的 CRC 校 验 原理 和 计算 方法 比较 清楚 


下 面 大 家 做 一 个 练习 : 假设 CRC 生 成 多 项 式 为 G(X)=X5 +X4 
+X+1， 要 发 送 的 二 进 制 序列 为 100101110， 求 CRC 校 验 码 是 多 少 ? 


5.3.3” 反 僻 检 测 法 


“反馈 检测 法 ”是 一 种 最 简单 、 最 容易 实现 ， 但 并 不 尝 用 的 差错 控 
制 方法 。 这 种 差错 控制 方法 的 信道 利用 率 低 ， 因 为 在 这 种 差错 控制 方 
法 中 每 个 数据 帧 均 要 求 至 少 在 信道 中 往返 传输 两 次 。 下 面具 体 介绍 。 


1. 反 馈 检测 法 基本 原理 


反馈 检测 法 不 需要 利用 前 面 介绍 的 PCC (奇偶 校 验 码 ， 和 CRC 
(循环 见 余 校 验 码 ) 检测 错 码 技术 ， 其 把 差错 检测 和 差错 纠正 的 任务 
全 部 交 给 发 送 冲 。 它 要 求 接受 端 在 接收 到 每 一 个 数据 巾 后 均 要 问 发 送 
端 发 送 一 个 表示 是 否 接收 了 该 数据 帧 的 反馈 信息 ， 且 这 个 反馈 信息 可 
征 原 来 由 发 送 冰 发 给 接收 端的 原始 数据 帧 。 发 送 端 在 收 到 接收 端 发 送 
的 反馈 信息 后 ， 通 过 对 比 保存 在 缓存 中 原来 该 帧 的 数据 来 判断 接收 端 
古 否 正确 接收 了 该 数据 帧 。 


这 种 要 求 接收 端 必 须 癌 发 送 端 反 馈 的 做 法 ， 有 些 类 似 于 我 们 回 某 
人 发 送 一 个 需要 对 方 确 认 的 重要 邮件 一 样 ， 如 有 条 收 件 人 收 到 了 你 发 送 
的 这 封 邮 件 ， 要 求 对 方 对 你 进行 回复 确认 ; 如 果 对 方 收 到 的 邮件 已 遭 
破坏 ， 也 可 以 同 你 反映 ， 然 后 你 可 以 重 发 这 封 邮件 给 他 ， 直 到 对 方 收 
到 了 正确 的 邮件 。 但 也 不 完全 与 上 述 过 程 等 同 ， 因 为 这 里 的 邮件 反馈 


并 不 需要 发 回 原来 邮件 的 全 部 内 容 ， 只 是 一 条 表示 收 到 邮件 了 的 反馈 


Es 
信息 。 


如 果 经 过 比较 发 现 ， 接 收 病 反 馈 来 的 某 数 据 帧 与 原始 帧 不 一 样 ， 
则 表明 对 应 帧 在 传输 过 程 中 出 现 了 差错 ， 接 收 端 接 收 到 的 对 应 帧 是 错 
误 的 ， 则 接收 端 向 发 送 端 发 送 一 个 DEL 字符 和 相应 的 帧 编号 (下 面 将 
介绍 到 ) ， 通 知 接收 端 删除 对 应 的 帧 ， 由 发 送 端 重 发 对 应 的 数据 帧 ， 
直到 接收 到 接收 端 反 馈 来 的 数据 对 应 帧 与 原来 发 送 的 该 帧 数据 完全 一 
样 为 止 ， 如 有 果 经 比较 接收 端 返 回来 的 某 帆 与 原来 发 送 的 对 应 帧 完全 一 
样 ， 则 表示 接收 端 已 正确 接收 到 该 数据 巾 ， 不 再 重 发 ， 继 续 发 送 下 一 
数据 巾 。 


2. 两 项 附加 技术 


从 以 上 反馈 检测 原理 可 以 发 现 ， 这 里 有 一 个 问题 ， 那 束 古 可 能 基 
些 原 因 导 和 致 一 些 数据 帧 在 传输 过 程 中 完全 丢失 了 ， 接 收 端 根本 没收 
到 这 些 数据 帧 ， 目 然 也 束 不 会 辣 发送 端 发 送 对 应 数据 帧 的 反馈 信息 
了 。 豆 像 你 有 要求 收 件 人 在 收 到 你 发 送 的 邮件 时 给 你 回信 ， 但 对 方 根本 
没收 到 你 的 邮件 ， 目 然 也 束 不 会 有 回信 了 ， 你 还 忌 在 那里 等 他 的 回 


信 。 


为 了 避免 出 现 这 种 情况 ， 通 常 引入 计时 器 (Timer) 来 限定 接收 端 
发 回 反馈 消息 的 时 间 ， 即 当 发 送 端 发 送 一 帧 数据 时 即 自动 启动 计时 


I 
dm 


， 如 有 果 在 计时 器 中 限定 的 时 间 内 仍 没 有 收 到 接收 病 发 来 的 反馈 信 

， 则 可 认为 该 帧 的 数据 传输 出 现 了 差错 或 丢失 ， 吏 主动 重新 发 送 该 

帧 。 束 像 你 对 某 人 发 送 邮 件 前 藉 告诉 对 方 , “我 现在 就 发 送 邮 件 给 你 ， 

你 必须 在 2 小 时 内 回复 我 是 否 收 到 了 这 封 邮件 ， 否 则 我 认为 你 没收 到 这 
封 邮件 ， 会 重新 发 一 封 给 你 ”。 


EU 


以 上 计时 妖 方 案 虽 然 解 决 了 由 于 数据 丢失 而 引发 的 意外 ， 但 可 能 
由 于 网 络 线路 比较 忙 ， 送 达 的 某 帧 数据 在 到 达 接 收 冰 时 有 所 延迟 ， 超 
出 了 计时 器 限定 的 时 间 范 围 ， 发 送 端 仍然 会 重 发 对 应 的 数据 帧 ， 这 样 
束 可 能 使 接收 端 多 次 接收 同一 数据 帧 了 。 为 了 防止 发 生 这 种 现象 ， 
在 “数据 链 路 层 ” 又 采取 了 “ 帧 编号 ”( 也 就 是 “ 帧 序列 号 ”) 方法 对 发 送 
的 每 个 数据 帧 进行 编号 (同一 数据 帧 编号 一 样 ， 无 论 发 送 多 少 次 ) ， 
从 而 使 接收 端 能 从 该 编号 来 区 分 是 新 发 来 的 帧 ， 还 是 已 经 接受 但 又 重 
新 发 来 的 帧 ， 从 而 确定 要 不 要 将 接收 到 的 帧 递交 给 网 络 层 。“ 数 据 链 路 
层 ” 通 过 使 用 “计数 占 ” 和 “ 帆 编 号 ”两 种 措施 来 保证 每 个 数据 帧 最 终 都 能 
被 正确 地 递交 给 目标 网 络 层 一 次 。 


5.3.4 至 朵 重 发 请 求 方案 


从 上 节 介绍 的 "反馈 检测 法 "差错 控制 原理 中 可 以 看 出 ， 其 虽然 简 
单 ， 容 易 实 现 ， 也 有 较 高 的 可 靠 性 ， 但 每 个 数据 帧 实际 上 在 信道 中 均 
被 传输 了 两 次 ， 造 成 信道 利用 率 降低 。 也 正如 此 ， 这 种 差错 控制 方法 
一 般 用 于 面向 字符 的 异步 传输 中 ， 因 为 在 这 种 情形 下 ， 传 输 的 数据 量 
比较 小 ， 信 道 传输 效率 并 不 是 主要 问题 


实用 的 差错 控制 方法 ， 既 要 求 传输 可 靠 性 高 ， 又 要 求 信道 利用 率 
高 。 为 此 可 使 发 送 端 将 要 发 送 的 数据 帧 附加 一 定 的 元 余 检 错 码 (如 
PPC、CRC 等 ) 一 并 发 送 ， 接 收 问 则 根据 检 名 码 对 数据 帧 进行 震 错 检 
测 ;大 发现 错 误 ， 融 返回 请 求 重 发 的 啊 应 ， 发 送 端 收 到 请 求 重 发 的 啊 
应 后 ， 便 重新 传送 该 数据 帧 。 这 种 差错 控制 方法 就 称 为 目 动 重 发 请 求 


(Automatic Repeat reQuest，ARQ) 法 。 


ARQ 差 错 控 制 方案 仅 需 返 回 少量 控制 信息 〈 接 收 端 不 必 重 传 整个 
数据 帧 ) ， 便 可 有 效 地 确认 所 发 数据 帆 是 否 正确 被 接收 。ARQ 法 有 几 
种 具体 的 实现 方案 ， 空 闲 重 发 请 求 \Idle RQ) 和 * 和 连续 重 发 请 
求 ”(Continuous RQ) 是 其 中 最 基本 的 两 种 方案 。 本 节 先 介绍 “空闲 重 
发 请 求 " 凑 错 控 制 方案 ， 下 世 将 介绍 连续 重 发 请 求 才 错 控 制 方案 。 


空闲 重 发 请 求 方案 又 称 停 -等 (Stop and Wait) 法 ， 该 方案 规定 发 
送 端 每 发 送 一 帧 后 就 要 停 下 来 ， 然 后 等 待 接收 端 发 来 的 确认 信息 (这 
就 是 停 -等 的 意思 ) ， 仅 当 接 收 端 确认 (ACK) 信息 后 才 继 续 发 送 下 一 
数据 帧 。 如 果 收 到 的 是 否认 (NAK) 消息 ， 表 示 接 收 端 接 收 的 数据 有 
错 ， 请 求 发 送 闹 重 发 。 男 外 ， 在 计时 右 超 时 时 ， 发 送 闹 也 会 重 发 对 应 
的 帆 。 


图 5-11a、b 所 示 分 别 是 正确 接收 效 据 时 的 数据 帧 发 送 流程 和 接收 到 
有 错误 数据 时 的 数据 帧 发 送 流程 。 


空 采 重 发 请 求 差 错 控制 方案 的 具体 实现 过 程 如 下 : 


1) 发 送 端 每 次 仅 将 当前 数据 帧 作为 待 确认 帧 保留 在 缓冲 存储 器 
中 ， 当 发 送 端 开始 发 送 数据 帧 (如 图 5-11 所 示 的 data0) 时 ， 随 即 启动 
计时 器 。 


2) 当 接 收 端 收 到 这 个 数据 帧 时 ， 先 利用 帧 中 附带 的 检 错 码 进 行 校 
验 ， 确 认 无 差错 后 ， 即 向 发 送 端 返回 一 个 确认 信息 (如 图 5-11a 所 示 的 
ACK0、ACK1 和 图 5-11b 所 示 的 ACK0) ; 当 检 测 到 该 帧 有 错误 时 ， 向 
发 送 端 返 回 一 个 否认 帧 (如 图 5-11b 所 示 的 NAK0) ， 同 时 丢弃 该 帧 。 


3) 如 果 发 送 端 在 计时 器 中 规定 的 时 间 内 收 到 来 自 接收 端的 确认 信 
尽 ， 即 将 计时 句 清 零 ， 清 除 缓存 中 的 竺 确认 巾 ， 然 后 才 开 始 下 一 数据 
帧 (如 图 5-11a 所 示 的 datal) 的 发 送 ;， 着 发 送 闻 在 规定 时 间 内 未 收 到 来 


自 接收 端的 确认 信息 〈 即 计时 器 超时 ) ， 则 重 发 存放 于 缓冲 器 中 的 待 
确认 数据 由 (如 图 5-11b 所 示 的 datal) 。 


发 送 data0 


收 到 错误 数据 
接收 端 


收 到 正确 数据 收 到 正确 数据 
ACKO 返回 ACK0 


发 送 data0 发 送 端 
| Eee 


发 送 端 接收 关 返回 ACK0 
综 发 datal datal 
继续 发 送 i 
datal | 收 到 正确 数据 发 送 datal 计时 需 超 时 
| datal 
返回 ACKI1 重 发 datal 
a ) 正确 b ) 错误 


图 5-11 空间 重 发 请 求 方案 原理 示例 


4) 后 续 数 据 帧 的 发 送 步 又 与 data0 蚌 的 发 送 一 样 。 


现在 来 打 个 与 这 里 所 介绍 的 空 几 重 发 请 求 差错 控制 方案 类 似 的 比 
方 。 一 个 牙牙 学 语 的 小 孩 ， 你 要 他 从 1 数 到 10。 由 于 他 非常 小 ， 对 这 十 
个 数字 记得 并 不 牢 ， 所 以 他 会 一 个 个 地 去 数 ， 而 且 每 数 完 一 个 数 ， 他 
都 会 停 下 来 ， 抬 起 头 望 着 你 ， 等 竺 你 的 点 头 ， 或 者 说 “对 ”， 然 后 他 才 
继续 往 下 数 。 你 对 他 点 头 或 者 说 “对 ”， 就 相当 于 你 向 他 发 回 了 一 个 确 
认 背 晨 。 


从 以 上 过 程 可 以 看 出 ， 空 闲 重 发 请 求 方案 除了 要 求 在 发 送 的 数据 
帆 中 携 市 一 定 的 检测 钳 码 外 ， 还 要 求 发 送 问 和 接收 端 都 有 一 个 用 于 存 
放行 确认 的 发 送 帧 和 待 癌 "网络 层 ? 近 区 的 数据 帆 的 缓冲 存储 空间 ， 但 
这 个 存储 空间 比较 小 ， 因 为 它 只 需要 临时 存放 一 个 数据 帧 。 


由 以 上 分 析 可 以 看 出 ， 这 种 ARQ 方 法 设计 简单 ， 容 易 实 现 ， 但 是 
这 种 方法 也 有 一 个 不 可 克服 的 缺点 ， 那 丈 是 每 传达 一 个 数据 帧 都 要 有 
一 个 等 待 时 间 ( 称 为 占 空 时 间 ) ， 信 道 的 有 效 利用 率 低 。 占 空 时 间 与 
传送 一 个 帧 的 全 部 时 间 的 比例 ， 称 为 占 空 比 。 数据 帧 越 短 ， 占 空 比 谍 
越 大 ， 相 当 于 信道 的 利用 率 越 低 ， 数据 帆 越 长 ， 占 至 比 束 越 小 ， 信 道 
的 利用 率 就 越 高 。 但 是 数据 帧 越 长 ， 出 错 的 概率 也 束 越 大 ， 从 而 出 现 

多 次 重 发 ， 因 此 传输 效率 也 不 会 太 高 。 正 因 如 此 才 有 下 面 将 要 介绍 的 
连续 重 发 请 求 差 错 控制 方案 。 


5.3.5 “连续 重 发 请 求 方 案 


为 了 减 小 占 空 比 ， 提 高 传输 效率 ， 人 们 又 提出 了 连续 重 发 请 求 
(Continuous ARQ) 的 差错 控制 方案 。 


连续 重 发 请 求 方案 是 指 发 送 端 可 以 连续 发 送 一 系列 数据 帧 (也 不 
总 是 不 断 地 发 送 ， 具 体 可 以 连续 发 送 多 少 个 央 ， 要 视 双 方 的 缓存 空间 
大 小 ， 即 窗口 大 小 而 定 ) ， 即 不 用 等 前 一 帧 被 确认 便 可 继续 发 送 下 一 
帧 ， 歼 率 大 大 提高 。 当然， 在 这 个 连续 发 送 的 过 程 中 也 可 以 接收 来 目 
接收 症 的 啊 应 消息 〈 可 以 是 确认 帧 ， 也 可 能 是 否认 帧 ) ， 发 送 端 同样 
可 以 对 传输 出 错 的 数据 帧 《如 接收 端 返回 了 和 否认 帧 ， 或 者 响应 计时 咒 
超时 的 帧 ) 进行 重 发 ， 具 体 处 理 方法 后 面 会 具体 介绍 。 


由 于 连续 重 发 请 求 方案 减少 了 等 竺 时间， 整个 通信 有 的 否 吐 量 就 提 
高 了 ， 但 在 这 种 重 发 请 求 方 案 中 ， 需 要 在 发 送 端 设置 一 个 较 大 的 缓冲 
存储 空间 ( 称 为 重 发 表 ) ， 用 以 存放 寿 干 待 确认 的 数据 巾 。 当 发 送 闻 
得 到 某 数 据 帧 的 确认 帧 后 ， 便 可 从 重 发 表 中 将 该 数据 帧 删除 。 


当 出 现 传输 差错 时 ， 连 续 重 发 请 求 方案 有 两 种 处 理 策略 ， 即 回 退 N 
巾 (GO-DACK-N) 策略 和 选择 重 发 《Selective Repeat) 策略 。 下 面 分 


别 予 以 介绍 。 


1. 回 退 N 帆 案 略 


回 退 N 帧 策略 的 基本 原理 是 ， 如 琳 发 送 闻 一 共 发 送 了 n 个 数据 帧 
(编号 从 0， 一 直到 n-1) ,但 收 到 接收 端 发 来 的 ACK 确 认 帧 中 少 了 某 
一 个 或 几 个 帆 的 ACK 确 认 帆 (要么 十 数 据 帧 出 现 了 丢失 ， 要 么 是 这 些 
帧 对 应 的 ACK 帧 或 者 NAK 帧 出 现 了 丢失 ， 最 终 造成 ACK 确 认 帧 序号 不 
连续 ) ， 或 者 在 接收 某 一 帧 时 检测 出 有 错 ， 接 收 端 发 送 一 个 NAK 否 认 
须 给 发 送 闹 ， 或 者 在 计时 右 超 时 后 仍 没有 收 到 某 个 帧 的 ACK 或 者 NAK 
帧 ， 则 发 送 问 可 以 判 晰 接收 端 最 后 一 个 正确 接收 的 帧 编号 ， 然 后 从 组 
存 空间 的 重 发 表 中 重 发 所 收 到 的 最 后 一 个 ACK 帧 序号 以 后 的 所 有 帧 。 


图 5-12 所 示 是 一 个 回 退 N 帧 差错 控制 的 示例 。 图 中 假定 发 送 完 8 号 
帕 后 ，0 号 和 1 号 帧 的 ACK 帧 已 收 到 ， 但 2 号 帧 的 ACK 上 帧 在 计时 絮 超 时 后 
还 未 收 到 ， 则 发 送 端 只 能 退回 ， 从 2 号 帧 开始 重 发 以 后 所 有 已 发 的 数据 
帧 《2~8 号 共 7 个 帧 ) ， 尽 管 或 许 后 面 3~8 号 帧 的 ACK 确 认 帧 已 收 到 。 当 
然 原来 已 发 的 这 些 帧 接收 端 会 目 动 删除 的 。 


发 送 方 \ 第 i、 
接收 方 [9 中， RE 


错 本 由 


图 5-12 回 退 N 帧 策略 差错 控制 原理 示意 图 
下 面 我 们 将 逐 层 深入 分 析 “ 回 退 N 帧 "策略 中 的 数据 处 理 流程 。 


(1) 理想 情形 下 的 数据 处 理 流程 


首 移 看 一 下 在 理想 状态 的 情形 ， 也 融 是 数据 师 和 确认 帆 都 不 发 生 
差错 或 丢失 的 情形 〈 也 就 是 不 存在 NAK 帧 返回 ， 不 存在 数据 帧 和 ACK 
帧 丢失 ， 也 不 存在 计时 器 超时 ) 下 的 数据 处 理 流 程 : 


1) 发 送 端 连续 发 送 数据 帧 ， 而 不 等 待 任何 数据 帧 的 ACK 帧 的 返 


2) 发 送 端 在 重 发 表 中 保存 所 发 送 的 每 个 数据 帧 的 备份 ; 


3) 接收 端 对 每 一 个 正确 收 到 的 数据 帧 返回 一 个 ACK 帧 ，ACK 帧 中 
包括 对 应 帧 的 编号 ; 


4) 接收 端 保存 一 个 接收 (次序) 表 ， 包 含 最 后 正确 收 到 的 数据 帧 
的 编号 ; 


5) 当 发 送 端 收 到 相应 数据 帧 的 ACK 帧 后 ， 发 送 端 即 从 重 发 表 中 删 
除 该 数据 帧 。 


(2) 存在 帧 差错 情形 下 的 数据 流程 


接 下 来 考虑 帧 (包括 数据 帧 和 响应 帧 出 现 差错 的 情形 下 回 退 N 帧 
策略 的 数据 处 理 流程 ， 这 里 的 “差错 ” 既 包 括 数据 帧 在 接收 端 检测 出 的 
差错 ， 也 包括 数据 帧 或 啊 应 帧 在 传输 过 程 中 出 现 丢 失 的 差错 。 此 时 ， 
回 退 N 巾 策 略 中 的 数据 处 理 流程 如 下 : 


1) 假设 发 送 的 第 N+1 个 帧 发 生 了 差错 ， 接 收 端 要 么 检测 出 第 N+1 
帧 有 错 ， 要 么 发 现 没有 接收 到 N+1 帧 ， 反 而 接收 到 了 第 N+2 帧 或 第 N+3 
蚌 ， 或 后 边 其 他 帆 ; 


2) 出 现 这 种 情况 时 ， 接 收 端 立即 返回 一 个 相应 的 未 正确 接收 的 否 
认 帧 NAK (N+1) ， 预 示 接 收 端 最 后 正确 收 到 的 是 第 N 帧 (N+1 帧 的 前 
一 帧 ) ;同时 对 后 面 每 个 失 序 的 数据 帧 ， 接 收 端 都 产生 相应 的 NAK 
帧 ， 和 否则 如 果 所 发 送 的 NAK (N+1) 帧 正好 丢失 或 出 错 ， 将 产生 和 死 
锁 ， 即 发 送 端 不 停 地 发 送 新 的 帧 ， 同 时 等 待 对 第 N+1 帧 的 确认 ， 而 接收 
端 不 停 地 清除 后 继 的 帧 ， 当 然 可 以 通过 超时 机 制 或 者 流量 控制 来 避免 
死 锁 的 发 生 (如 滑动 窗口 法 ， 具 体 将 在 本 章 后 面 介绍 数据 链 路 层 的 流 
量 控制 原理 时 介绍 ) ; 


3) 发 送 端 在 收 到 NAK (N+1) 帧 ， 或 者 收 到 了 NAK (N+2) 、 
NAK (N+3) ...... 帧 时 ， 从 重 发 表 中 重 发 第 N+1 帧 或 者 对 应 的 NAK 帧 
中 序号 所 对 应 的 帧 ， 同 时 接收 端 清除 所 有 失 序 的 帧 (从 第 N+2 帧 或 者 对 
应 NAK 帧 中 序号 所 对 应 的 帧 开始 ， 直 到 重新 正确 接收 到 重 发 的 第 N+1 
或 者 对 应 NAK 帧 中 序号 所 对 应 的 帧 ); 


4) 接收 端 重新 收 到 第 N+1 帧 ， 或 者 对 应 的 NAK 帧 中 序号 所 对 应 的 
炭 ， 接 收 闹 束 继 续 正 单 操作 。 


以 上 流程 看 似 比 较 复 杀 ， 其 实 原 理 很 简单 。 打 个 比方 来 说 吧 ， 比 
如 我 们 经 常 要 自己 小 孩 从 1 数 到 100， 以 检验 他 的 数 数 能 力 。 人 小 孩 正 在 
数 着 ， 你 突然 发 现 某 个 数 数 得 不 正确 (如 数 到 42 时 本 应 是 43， 却 数 成 
了 53) ， 或 者 中 间 漏 了 一 个 或 多 个 数 如 数 到 42 时 ， 本 应 是 43 却 数 成 
跳 过 了 ， 从 45 开 始 数 了 ) ， 你 就 会 要 求 小 孩 从 出 现 错误 的 那个 数 开始 
重 数 (如 从 43 开 始 数 ) ， 尽 管 在 后 面 大 多 数 是 数 得 正确 的 。 这 就 是 回 
退 N 帧 策略 的 差错 控制 原理 。 


2. 克 择 重 发 策略 


回 退 N 帧 策略 因 可 以 连续 发 送 数 据 帧 而 提高 了 传输 效率 ， 但 也 有 不 
利 的 方面 ， 那 就 是 在 重 发 时 必须 把 原来 已 正确 传送 过 的 数据 帧 再 次 发 
送 ， 仅 仅 是 因为 这 些 数据 帧 之 前 的 菜 个 数据 帆 或 确认 帧 发 生 了 差 销 ， 
这 样 又 使 传输 效率 降低 。 所 以 当 通 信和 链 路 的 传输 质量 很 过 、 误 码 率 较 
大 时 ， 回 退 N 帆 案 略 束 没 什么 优势 了 ， 因 为 这 时 可 能 经 稼 要 重 传 大 量 的 
数据 帧 。 


为 了 弥补 回 退 N 帧 策略 的 不 足 ， 男 一 种 效率 更 高 的 差错 控制 策略 
一 一 选择 重 发 策略 诞生 了 。 在 这 个 鞭 错 控制 策略 中 ， 当 接收 端 发 现 茶 
帧 出 错 后 ， 其 后 继续 送 来 的 正确 帧 虽然 不 能 立即 递交 给 接收 端的 “网 络 
层 "”， 但 接收 端 仍 可 接收 下 来 ， 移 存放 在 一 个 缓冲 区 中 ， 同 时 通过 加 发 
送 端 发 送 NAK 否 认 帧 ， 要 求 发 送 端 重新 传送 出 错 的 那 一 帧 。 一 旦 收 到 


重 狐 发 来 的 正确 巾 后 ， 就 可 以 与 原 已 存 于 绥 冲 区 中 的 其 余 帧 一 起 按 正 
确 的 顺序 递交 给 网 络 层 。 


选择 重 发 集 略 规定 ， 当 发 送 剖 收 到 包含 出 错 帧 序号 的 NAK 帧 时 ， 
据 此 序号 从 重 发 表 中 选 出 相应 帧 的 备份 ， 直 接 择 入 到 发 送 帧 队列 的 前 
面 给 予 重 发 ， 因 为 重 发 表 的 帧 重 发 是 按照 FIFO (先进 先 出 ) 的 机 制 进 
行 排列 的 ， 揪 在 前 面 是 为 了 可 以 最 先 重 发 ， 避 免 了 对 后 继 正 确 数据 帆 
的 多 余 重 发 ， 使 得 传输 效率 明显 提高 


如 于 仍 用 小 孩 数 数 来 打 比 方 的 话 ， 束 是 你 和 多 让 小 孩 目 己 一 直 数 下 
去 ， 发 现 数 错时 你 记 下 来 〈 不 要 打 断 他 正常 的 数 数 流程 ) ， 当 小 孩 数 
完 后 你 再 根据 这 些 错误 要 求 小 孩 重 数 对 应 的 数 束 行 了 ， 而 不 必要 求 他 
从 错误 的 地 方 重新 数 下 去 。 


下 面 也 分 两 种 情况 来 讨论 “选择 重 发 "策略 的 数据 处 理 方法 。 


(1) 数据 帧 出 现 差错 情形 下 的 处 理 流 程 


以 下 是 当 数 据 帧 有 差错 《包括 接收 端 检测 到 所 接收 的 数据 帧 有 差 
错 ， 或 者 有 数据 帧 丢失 两 种 可 能 ) 时 , “选择 重 发 "策略 的 数据 处 理 流 
程 : 


1) 发 送 端 连 续 发 送 多 个 数据 帧 ， 接 收 端 对 每 个 已 正确 接受 的 数据 
帧 返回 一 个 ACK 帧 ; 现 假设 第 N+1 个 帧 出 现 差 错 或 丢失 如 果 检 测 到 第 


N+1 个 帧 有 错误 ， 则 向 发 送 端 返 回 一 个 否认 NAK (N+1) 帧 ， 如果 一 直 
到 收 到 第 N+2 个 数据 帧 时 还 没收 到 第 N+1 帧 ， 则 表明 该 帧 已 委 失 ， 接 收 
端 不 产生 任何 动作 ; 但 无 论 结果 如 何 ， 已 正确 接收 的 数据 帧 ， 如 第 N 个 
帧 、 第 N+2 个 帧 、 第 N+3 个 帧 ..……. 仍 会 向 发 送 方 返回 确认 ACK 帧 ; 


2) 当 发 送 端 收 到 来 自 接收 端的 否定 NAK (N+1) 或 者 收 到 第 N+2 
帧 的 ACK 帧 时 ， 会 检测 出 其 失 序 (因为 按 顺 序 ， 在 收 到 ACK (N+2) 
帧 之 前 应 该 是 收 到 ACK (N+1) 帧 ) ， 得 知 第 N+1 帧 没有 被 确认 。 将 第 
N+2 帕 从 重 发 表 中 清除 ， 并 在 继续 发 送 后 继 数 据 帧 之 前 重 发 第 N+1 帧 。 


图 中 5-13 所 示 为 由 于 接收 器 检测 到 2 号 帧 有 错 ， 向 发 送 端 发 送 了 一 
个 否认 巾 NAK2， 要 求 发 送 端 选择 重 发 2 号 帧 的 示意 图 。 从 中 可 以 看 限 
出 , “选择 重 发 ”策略 下 只 需 发 送 有 错 的 帧 ， 而 不 会 发 送 从 有 错 帧 开始 
后 面 所 的 帜 ， 显 然 减少 了 信道 资源 浪费 ， 提 高 了 传输 效率 ， 但 要 求 发 
送 端 和 接收 器 部 有 尼 够 大 的 缓冲 区 空间 ， 以 便 存 储 多 个 巾 的 重 发 表 和 
预 提 区 数 据 帧 。 


存储 的 数据 由 ~ gi 


图 5-13 “选择 重 发 "策略 差错 控制 原理 示意 图 


(2) 响应 帧 出 现 差 错 情形 下 的 数据 处 理 流 程 


在 响应 帧 (包括 确认 ACK 帧 和 否认 NAK 帧 ) 出 现 差 错时 ， 也 就 是 
本 应 接收 的 是 第 N 个 帧 的 响应 帧 却 接收 到 了 第 N+1 个 帧 的 响应 帧 情况 
下 ， 在 该 情形 下 数据 处 理 流程 如 下 〈 现 以 ACK 帧 出 错 进行 介绍 ， 与 
NAK 帧 出 错 的 处 理 流程 一 样 ) : 


1) 当 发 送 端 已 到 了 第 N-1 个 帧 的 ACK 帧 ， 接 下 来 应 该 收 到 的 是 第 
N 个 帧 的 ACK 帧 ， 而 偶偶 收 到 的 是 第 N+1 个 帆 的 ACK 帆 ; 


2) 发 送 端 在 收 到 ACK (N+1) 帧 后 ， 检 测 出 在 重 发 表 中 第 N 个 帧 
都 还 没收 到 ACK 帧 ， 因 此 认为 第 N 个 帧 出 现 了 差错 (事实 上 并 不 是 这 样 
的 ) ， 重 发 第 N 个 帧 ; 


3) 接收 端 在 收 到 发 送 端 重 发 的 第 N 个 帧 ， 搜 索 接 收 表 并 确定 第 N 
蚜 已 被 正确 接收 ， 因 此 认定 这 个 重 发 的 第 N 帧 十 重复 的 ， 于 是 直接 删除 
这 个 重 发 的 第 N 帧 ， 并 返回 一 个 ACK (N) 给 发 送 端 ， 以 使 发 送 端 从 重 
发 表 中 删除 第 N 帧 。 这 样 就 达到 了 啊 应 帧 出 现 差 错时 的 错误 纠正 。 


5.3.6” 海 明 纠 错 人 码 


海 明 码 (Hamming Code) 是 一 个 可 以 有 多 个 校 验 位 ， 具 有 检测 并 
纠正 一 位 错误 代码 功能 的 纠 错 码 ， 所 以 它 也 仅 用 于 信道 特性 比较 好 的 
环境 中 ， 如 以 太 局 域 网 中 ， 因 为 如 果 信 道 特性 不 好 的 情况 下 ， 出 现 的 


错 充 通 币 不 是 一 位 。 


海 明 码 的 检 错 、 纠 错 基 本 思想 是 将 有 效 信息 按 某 种 规律 分 成 寿 干 
组 ， 每 组 安排 一 个 校 验 位 进行 奇偶 性 测试 ， 然 后 产生 多 位 检测 信息 ， 
并 从 中 得 出 具体 的 出 错位 置 ， 最 后 通过 对 错误 位 取 反 (也 是 原来 是 1 就 
变 成 0， 原 来 是 0 束 变 成 1) 来 将 其 纠正 。 


要 采用 海 明 码 纠 错 ， 需 要 按 以 下 步骤 来 进行 : 计算 校 验 位 数 - 确 
定 校 验 码 位 置 一 确定 校 验 码 -实现 校 验 和 纠 错 。 下 面 来 具体 介绍 这 几 


个 步 又 。 


1. 计 算 校 验 位 数 


要 使 用 海 明 码 纠 错 ， 首 先 束 要 确定 发 送 的 数据 所 需要 的 校 验 码 
(也 就 是 “ 海 明 码 ”) 位 数 (也 称 校 验 码 长 度 。 它 是 这 样 的 规定 的 : 
假设 用 N 表 示 添 加 了 校 验 码 位 后 整个 信息 的 二 进 制 位 数 ， 用 K 表 示 其 中 
有 效 信息 位 数 ，r 表 示 添 加 的 校 验 码 位 ， 它 们 之 间 的 关系 应 满足 : 

N=K+r<2' -1 ° 


如 K=5， 则 要 求 2 -r>5+1=6， 根 据 计 算 可 以 得 知 r 的 最 小 值 为 4， 也 
就 是 要 校 验 5 位 信息 码 ， 则 要 插入 4 位 校 验 码 。 如 果 有 效 信息 位 数 是 8， 
则 要 求 27 -r>8+1=9， 根 据 计算 可 以 得 知 f 的 最 小 值 也 为 4 根据 经 验 总 
结 ， 得 出 信息 码 和 校 验 码 位 数 之 间 的 关系 如 表 5-1 所 示 。 


表 5-1 信息 码 位 数 与 校 验 码 位 数 之 间 的 关系 


2. 确 定 校 验 码 位 置 


上 一 步 我 们 确定 了 对 应 信息 中 要 插入 的 校 验 码 位 数 ， 但 这 还 不 
够 ， 因 为 这 些 校 验 码 不 是 直接 附加 在 信息 码 的 前 面 、 后 面 或 中 间 的 ， 
而 是 分 开 插 入 到 不 同 的 位 置 的 。 但 不 用 担心 ， 校 验 码 的 位 置 很 容易 确 
定 的 ， 那 束 是 校 验 码 必 须 是 在 2? 次 方位 置 ， 如 第 1 位 ，2 位 ，4 位 ，8 
位 ，16f2 921 0 Dh 从 最 左 
边 的 位 数 起 ) ， 这 样 一 来 就 知道 了 信息 人 码 的 分 布 位 置 ， 也 就 是 非 2 次 
方 的 位 置 ， 如 第 3 位 ，5 位 ，6 位 ，7 位 ，9 位 ，10 位 ，11 位 ，12 位 ，13 
人 (从 最 左边 的 位 数 起 ) 。 


举 一 个 例子 ， 假 设 现 有 一 个 8 位 信息 码 ， 妈 bl1、b2、b3、b4、b5、 
b6、b7、b8， 由 表 5-1 得 知 ， 它 需要 插入 4 位 校 验 码 ， 即 pl1、p2、p3、 
p4， 也 就 是 整个 经 过 编码 后 的 数据 码 ( 称 为 码 字 ) 共有 12 位 。 根 据 以 


上 介绍 的 校 验 码 位 置 分 布 规则 可 以 得 出 ， 这 12 位 编码 后 的 数据 束 是 
pl1、p2、b1、p3、b2、b3、b4、p4、b5、b6、b7、b8。 


假设 原来 的 8 位 信息 码 为 10011101， 因 还 没有 求 出 各 位 校 验 码 值 ， 
现在 这 些 校 验 码 位 都 用 “? ”表示 ， 最 终 的 码 字 为 : 二 13 001- 
1101。 


3. 确 定 校 验 码 


经 过 前 面 的 两 步 ， 我 们 已 经 确定 了 所 需 的 校 验 码 位 数 和 这 些 校 验 

码 的 插入 位 置 ， 但 这 还 不 够 ,还 得 确定 各 个 校 验 码 值 。 这 些 校 验 码 的 
值 不 是 随意 的 ， 每 个 校 验 位 的 值 代 表 了 代码 字 中 部 分 数据 位 的 奇偶 性 
(最 终 要 根据 是 采用 奇 校 验 还 是 侦 校 验 来 确定 ) 


， 其 所 在 位 置 决定 了 
要 校 验 的 比特 位 序列 。 总 的 原则 是 : 第 i 位 校 验 码 从 当前 位 开始 ， 每 次 
车 续 校 验 i 〈 这 里 是 数值 i， 不 是 第 i 位 ， 下 同 ) 位 后 再 跳 过 i 位 ， 然 后 再 
连续 校 验 i 位， 再 跳 过 i 位， 以 此 类 推 。 最 后 根据 所 采用 的 是 奇 校 验 还 是 
偶 校 验 即 可 得 出 第 位 校 验 码 的 值 。 


(1) 计算 方法 
校 验 码 的 具体 计算 方法 如 下 : 


p1 (第 1 个 校 验 位 ， 也 是 整个 码 字 的 第 1 位 ) 的 校 验 规则 是 : 从 当 
前 位 数 起 ， 校 验 1 位 ， 然 后 跳 过 1 位 ， 再 校 验 1 位 ， 再 跳 过 1 位 ，.……… 。 


这 样 就 可 得 出 p1 校 验 码 位 可 以 校 验 的 码 字 位 包括 : 第 1 位 (也 就 是 p1 本 
身 ) ， 第 3 位 ， 第 5 位 ， 第 7 位 ， 第 9 位 ， 第 11 位 ， 第 13 位 ， 第 15 


人 。 然后 根据 所 采用 的 是 奇 校 验 还 古 侦 校 验 ， 最 终 可 以 确定 该 
校 验 位 的 值 。 


p2 (第 2 个 校 验 位 ， 也 是 整个 码 字 的 第 2 位 ) 的 校 验 规则 是 : 从 当 
前 位 数 起 ， 连 续 校 验 2 位 ， 然 后 跳 过 2 位 ， 再 连续 校 验 2 位 ， 再 跳 过 2 
位 ，....…. 。 这样 就 可 得 出 p2 校 验 码 位 可 以 校 验 的 码 字 位 包括 : 第 2 位 

(也 就 是 p2 本 身 ) ， 第 3 位 ， 第 6 位 ， 第 7 位 ， 第 10 位 ， 第 11 位 ， 第 14 
7 。 同样 根据 所 采用 的 是 奇 校 验 还 是 侦 校 验 ， 最 终 可 
以 确定 该 校 验 位 的 值 。 


p3 (第 3 个 校 验 位 ， 也 是 整个 码 字 的 第 4 位 ) 的 校 验 规则 是 : 从 当 
前 位 数 起 ， 连 续 校 验 4 位 ， 然 后 跳 过 4 位 ， 再 连续 校 验 4 位 ， 再 跳 过 4 
人 。 这 样 承 可 得 出 p4 校 验 码 位 可 以 校 验 的 码 字 位 包括 : 第 4 位 

(也 就 是 p4 本 身 ) ， 第 5 位 ， 第 6 位 ， 第 7 位 ， 第 12 位 ， 第 13 位 ， 第 14 
位 ， 第 15 位 ， 第 20 位 ， 第 21 位 ， 第 22 位 ， 第 23 位 ，.……. 。 同样 根据 所 
采用 的 是 奇 校 验 还 是 偶 校 验 ， 最 终 可 以 确定 该 校 验 位 的 值 。 


p4 〈 第 4 个 校 验 位 ， 也 是 整个 码 字 的 第 8 位 ) 的 校 验 规则 是 ， 从 当 
前 位 数 起 ， 连 续 校 验 8 位 ， 然 后 跳 过 8 位 ， 再 连续 校 验 8 位 ， 再 跳 过 8 
位 ，...... 。 这 样 就 可 得 出 p4 校 验 码 位 可 以 校 验 的 码 字 位 包括 : 第 8 位 

(也 就 是 p4 本 身 ) ， 第 9 位 ， 第 10 位 ， 第 11 位 ， 第 12 位 ， 第 13 位 ， 第 14 


位 ， 第 15 位 ， 第 24 位 ， 第 25 位 ， 第 26 位 ， 第 27 位 ， 第 28 位 ， 第 29 位 ， 
第 30 位 ， 第 31 位 ，...... 。 同样 根据 所 采用 的 是 奇 校 验 ， 还 是 偶 校 验 ， 
最 终 可 以 确定 该 校 验 位 的 值 。 


我 们 把 以 上 这 些 校 验 码 所 校 验 的 位 分 成 对 应 的 组 ， 它 们 在 接收 端 
的 校 验 结果 (通过 对 各 校 验 位 进行 逻辑 “ 异 或 运算 ”得 出 ) 对 应 表示 为 
GlI~Gl* G3* C1 .... (正常 情况 下 均 为 0) 。 


(2) 校 验 码 计算 示例 


同样 举 上 面 的 例子 来 说 明 ， 码 字 为 2?_123_0013_1101。 


先 求 第 1 个 “? ”( 也 就 是 p1， 第 1 位 ) 的 值 ， 因 为 整个 码 字 长 度 为 
12 (包括 信息 码 长 和 校 验 码 长 ) ， 所 以 可 以 得 出 本 示例 中 p1 校 验 码 校 
验 的 位 数 是 1、3、5、7、9、11 共 6 位 。 这 6 位 中 除了 第 1 位 〈 也 残 是 pl 
位 ) 不 能 确定 外 ， 其 余 5 位 的 值 都 是 已 知 的 ， 分 别 为 1、0、1、1、0。 
现 假设 采用 的 是 偶 校 验 (也 就 是 要 求 整 个 被 校 验 的 位 中 的 “1” 的 个 数 为 
偶数 ) ， 从 已 知 的 5 位 码 值 可 知 ， 已 有 3 个 “1”， 所 以 此 时 p1 位 校 验 码 的 
值 必须 为 “1”， 得 出 pl1=1。 


再 求 第 2 个 “? ”( 也 就 是 p2， 第 2 位 ) 的 值 ， 根 据 以 上 规则 可 以 很 
快 得 出 本 示例 中 p2 校 验 码 校 验 的 位 数 是 2、3、6、7、10、11， 也 是 一 


共 6 位 。 这 6 位 中 除了 第 2 位 (也 就 是 p2 位 ) 不 能 确定 外 ， 其 余 5 位 的 值 

都 是 已 知 的 ， 分 别 为 1、0、1、1、0。 现 假设 采用 的 是 偶 校 验 ， 从 已 知 
的 5 位 码 值 可 知 ， 也 已 有 3 个 “1”， 所 以 此 时 p2 位 校 验 码 的 值 必须 为 “1”， 

得 出 p2=1。 


再 求 第 3 个 “? ”( 也 就 是 p3， 第 4 位 ) 的 值 ， 根 据 以 上 规则 可 以 很 
快 得 出 本 示例 中 p3 校 验 码 校 验 的 位 数 是 4、5、6、7、12， 一 共 5 位 。 这 
5 位 中 除了 第 4 位 (也 就 是 p3 位 ) 不 能 确定 外 ， 其 余 4 位 的 值 都 是 已 知 
的 ， 分 别 为 0、0、1、1。 现 假设 采用 的 是 侦 校 验 ， 从 已 知 的 4 位 码 值 可 
知 ， 也 已 有 2 个 “1”， 所 以 此 时 p2 位 校 验 码 的 值 必须 为 “0”， 得 出 p3=0。 


最 后 求 第 4 个 “? ” (也 就 是 p4， 第 8 位 ) 的 值 ， 根 据 以 上 规则 可 以 
很 快 得 出 本 示例 中 p4 校 验 码 校 验 的 位 数 是 8、9、10、11、12 〈 本 来 是 
可 以 连续 校 验 8 位 的 ， 但 本 示例 的 码 字 后 面 的 长 度 没 有 这 么 多 位 ， 所 以 
只 校 验 到 第 12 位 止 ) ， 也 是 一 共 5 位 。 这 5 位 中 除了 第 8 位 〈 也 就 是 p4 
位 ) 不 能 确定 外 ， 其 余 4 位 的 值 都 是 已 知 的 ， 分 别 为 1、1、0、1。 现 假 
设 采 用 的 是 侦 校 验 ， 从 已 知 的 4 位 码 值 可 知 ， 已 有 3 个 “1”， 所 以 此 时 p2 
位 校 验 码 的 值 必 须 为 “1”"， 得 出 p4=1。 


最 后 就 可 以 得 出 整个 码 字 的 各 个 二 进 制 值 码 字 为 111000111101 (和 带 
阴影 的 4 位 就 是 校 验 码 ) 。 


4. 实 现 校 验 和 纠 错 


里 然 上 一 步 已 把 备 位 校 验 码 求 出 来 了 ， 但 是 如 何 实现 检测 出 哪 一 
位 在 传输 过 程 中 出 了 差错 呢 ? ( 海 明 码 也 只 能 检测 并 纠正 一 位 错误 ) 
它 又 是 如 何 实现 对 错误 的 位 进行 纠正 的 呢 ? 其 实 了 最 关键 的 原因 就 是 海 
明码 是 一 个 多 重 校 验 码 ， 也 就 是 码 子 中 的 信息 码 位 可 同时 被 多 个 校 验 
码 校 验 ， 然 后 通过 这 些 码 位 对 不 同 校 验 码 的 联动 影响 最 终 可 以 找 出 是 
哪 一 位 出 错 了 


(1) 海 明 码 的 差错 检测 


现 假设 整个 码 字 一 共 是 18 位 ， 根 据 表 5-1 可 以 很 快 得 出 ， 其 中 有 5 位 
苹 校 验 码 ， 再 根据 本 广 前 面 介绍 的 校 验 码 校 验 规则 可 以 很 快 得 出 各 校 
验 码 所 校 验 的 码 字 位 ， 如 表 5-2 所 示 。 


表 5-2 ”各 校 验 码 校 验 的 码 字 位 对 照 表 


EE FT 
EE EE EE EN EE 
LE | www 
FE| | | | www ww 
Pm | | | | | | ww 
| 


注 ; 不 带 阴 影 的 名 位 是 对 应 的 校 验 码 所 在 的 位 ， 而 带 阴 影 的 名 位 是 该 校 验 码 要 进行 校 验 的 数据 位 。 


从 表 中 可 以 得 出 以 下 两 个 规律 : 


口 所 有 校 验 码 所 在 的 位 古 由 对 应 的 校 验 码 进 行 校 验 的 ， 如 第 1 位 
(只 由 p1 校 验 ， 、 第 2 位 (只 由 p2 校 验 ) 、 第 4 位 (只 由 p3 校 验 ) 、 第 8 


位 (只 由 p4 校 验 ; 、 第 16 位 (只 由 p5 校 验 ) ，.……. 也 就 是 这 些 位 如 果 
发 生 了 差错 ， 影 响 的 只 是 对 应 的 校 验 码 的 校 验 结果 ， 不 会 影响 其 他 校 
验 码 的 校 验 结果 。 这 点 很 重要 ， 如 果 最 终 发 现 只 是 一 个 校 验 组 中 的 校 
验 结果 不 符 ， 则 直接 可 以 知道 是 对 应 校 验 组 中 的 校 验 码 在 传输 过 程 中 
出 现 了 差错 。 


口 所 有 信息 码 位 均 被 至 少 两 个 校 验 码 校 验 了 ， 也 束 是 至 少校 验 了 
两 次 。 查 看 对 应 的 是 哪 两 组 校 验 结 来 不 人 特 ， 然 后 根据 表 5-2 整 可 以 很 快 
确定 是 哪 位 信息 码 在 传输 过 程 中 出 了 差错 。 


海 明 码 校 验 的 方式 就 是 各 校 验 码 对 它 所 校 验 的 位 组 进行 异 或 运 
算 ， 即 : 


Gl=pl1®@b1®b2@®@b4@®b5@®...... 


G2=p2@®@bl1@®@b3®@b4@b6@®@b7@b10@®b11@®...... 


G3=p3@®@b2@b3@b4@b8@bI@b10@b11®...... 


G4=p4@®@b5@b6@b7@b8@bI@b10@®b11®...... 


G5=p5@®@b12@®@b13®@b14@®@b15@®@b16@®b17@®@b18@®@b19@b20@®@b21@b11 
©®b23@®@b24@®@b25@b26@...... 


正常 情况 下 (也 就 是 整个 码 字 不 发 生 差 错 的 情况 下 ) ， 在 采用 偶 
校 验 时 ， 各 校 验 组 通过 异 或 运算 后 的 校 验 结果 均 应 该 是 为 0， 也 就 是 前 
面 所 说 的 G1、G2、G3、G4，..……. 均 为 0， 因 为 此 时 1 为 偶数 个 ， 进 行 
异 或 运算 后 就 是 0;， 而 采用 奇 校 验 时 ， 各 组 校 验 结果 均 应 是 为 1。 


现在 举 一 个 例子 来 说 明 ， 假 设 传输 的 海 明 码 为 1900111101 (一 
共 12 位 ， 带 阴影 的 4 位 就 是 校 验 码 ) ， 从 中 可 以 知道 它 有 4 个 校 验 组 : 
G1、G2、G3、G4， 然 而 到 达 接 收 端 经 过 校 验 后 发 现 只 有 G4=1 〈 也 就 
是 只 有 这 组 校 验 结果 不 等 于 0) ， 通 过 前 面 介 绍 的 校 验 规 律 可 以 很 快 地 
发 现 是 G4 校 验 组 中 的 p4 校 位 码 (也 就 是 整个 码 字 中 的 第 8 位 ) 错 了 ( 因 
为 只 有 一 组 校 验 结果 出 现 差 错时 ， 则 肯定 只 是 对 应 的 校 验 位 出 了 差 
错 ) ， 也 就 是 最 终 的 码 字 变 成 了 : 111000001101 。 


再 假设 G3、G4 两 个 校 验 值 都 不 为 0， 也 就 是 都 等 于 1。 通 过 表 5-2 所 
示 比 较 G3、G4 两 个 校 验 组 〈 注 意 本 示例 中 码 字 长 度 一 共 才 12 位 ， 只 需 
要 比较 前 12 位 ) 中 共同 校 验 的 码 位 可 以 很 快 发 现 是 b8， 也 就 是 第 12 位 
出 现 了 差错 ， 也 就 是 最 终 的 码 字 变 成 了 : 111000011100 。 


经 验 之 谈 ”这 里 一 定 要 注意 ， 最 终 有 多 少 个 校 验 组 出 现 差 错 也 不 
是 随意 的 ， 一 定 要 结合 实际 传输 的 码 字 长 度 来 考虑 。 如 上 例 一 共 12 
位 ， 如 果 换 成 了 16 位 的 码 字 ， 且 当 b9 位 出 现 差 错时 ， 则 G1、G3、G4 一 
定 会 同时 出 现 错误 ， 因 为 b9 这 个 位 是 三 个 校 验 组 同时 校 验 的 ， 只 要 它 
一 出 错 ， 肯 定 会 同时 影响 这 三 个 校 验 组 的 值 。 同 理 ， 如 果 是 b11 位 出 现 


了 差错 ， 因 为 它 同时 受 G1、G2、G3、G4 四 个 校 验 组 校 验 ， 所 以 这 四 
个 校 验 组 结果 都 将 出 现 错误 。 


(2) 海 明 码 的 差错 纠正 


仿 测 出 站 哪 位 出 现 了 老 错 还 不 够 ， 因 为 海 明 码 具有 纠正 一 位 错误 
的 能 力 ， 所 以 还 需要 完成 纠 错过 程 。 这 个 过 程 的 原理 比较 简单 ， 就 是 
直接 对 错误 的 位 进行 取 反 或 者 加 “1” 操 作 ， 使 它 的 值 由 原来 的 “1” 变 
成 “0”， 或 由 原来 的 “0” 变 成 “1” (因为 二 进 制 中 每 一 位 只 能 是 这 二 者 之 
Ee 


以 上 就 是 海 明 码 的 莽 错 检测 和 差错 纠正 原理 了 ， 虽 然 比 单纯 的 奇 
偶 校 验 码 复 杂 些 ， 但 只 要 理 清 了 思路 ， 还 是 比较 位 单 的 。 


5.4 流量 欣 制 


介绍 完 复杂 的 数据 链 路 层 “ 差 错 控 制 * 功 能 后 ， 接 下 来 介绍 数据 链 
路 层 的 “流量 控制 * 功 能。 其 实在 上 市 介绍 差错 控制 功能 时 束 提 人 到 了 尝 
量 控 制 功能 ， 因 为 一 些 差 错 控 制 方案 本 身 束 具有 一 定 的 流量 控制 功 
能 ， 如 前 面 介 绍 的 空 几 重 发 请 求 方 案 中 规定 ， 发 送 端 每 发 完 一 个 数据 
帧 后 把 这 个 帧 保存 在 缓存 空间 中 ， 然 后 束 集 下 来 等 待 接收 端 发 来 的 确 
认 消 肯 ， 然 后 才能 继续 发 送 下 一 帧 ， 这 就 可 以 控制 路 中 的 数据 流量 。 
在 连续 重 发 请 求 方案 中 ， 昌 然 发 送 端 可 以 一 次 发 送 多 个 数据 帧 ， 但 是 
也 不 是 没有 限制 的 ， 因 为 发 送 端 需要 把 每 次 发 送 的 数据 帧 保存 在 缓存 
空间 中 ， 接 收 疾 也 要 把 癌 网 络 层 提交 的 数据 帧 完 保存 在 缓存 空间 中 ， 
所 以 最 终 一 次 能 发 送 多 少 个 帆 ， 有 是 由 双方 缓存 空间 大 小 决定 的 。 这 丈 
征 本 万 后 面 将 要 提 到 的 “窗口 大 小 ”。 


数据 链 路 层 的 流量 控制 方案 主要 有 两 种 ， 一 种 是 适用 于 面向 字符 
的 异步 通信 协议 (如 RS 一 一 232) 中 的 简单 流量 控制 方案 一 一 
XON/XOFF (继续 /停止 方案 ; 男 一 种 是 适用 于 大 量 数据 通信 环境 中 
的 “滑动 窗口 机 制 ”。 


5.4.1 XON/XOFF 流 量 控 制 方案 


XON/XOFF (transmitter on/transmitter off， 继 续 传 输 / 停 止 传输 ) 
是 一 种 流量 控制 协议 ， 常 用 于 数据 传输 速率 大 于 等 于 1200bps， 而 接收 
端 数 据 人 处 理 速率 远 小 于 这 个 值 《也 就 是 通信 双方 速率 不 同步 ) 的 情 
形 ， 通 过 对 发 送 端的 数据 传输 速率 进行 控制 ， 以 达到 与 接收 数据 数据 
处 理 速率 匹配 。 


XON/XOFF (继续 /停止 ) 是 一 种 最 简单 的 流量 控制 技术 ， 主 要 适 
用 于 异步 通信 中 ， 接 收 端 通 过 使 用 特殊 字符 来 控制 发 送 端 数据 的 发 
送 。 其 基本 思想 是 ， 当 接收 问 认 为 不 能 继续 接收 数据 时 《也 束 是 接收 
端的 缓存 空间 满 了 或 者 接近 满 时 ) ， 接 收 端 会 向 发 送 端 发 送 一 个 
XOFF 控 制 学 符 ， 当 发 送 并 收 到 对 应 的 XOFF 挥 制 学 符 时 就 停止 数据 的 
继续 发 送 ， 当 接收 端 可 以 继续 接收 数据 时 ， 接 收 端 会 再 癌 发 送 端 发 送 
一 个 XON 控 制 字符 ， 发 送 端 收 到 这 个 控制 字符 后 就 知道 可 以 恢复 数据 
发 送 了 ， 继 续 发 送 数据 ， 一 直 这 么 循环 下 去 。 


其 中 XON 采 用 ASCII 字 符 集 中 的 控制 字符 DC1 (十 进 制 值 为 17， 


六 进 制 值 为 11， 相 当 于 按 下 “Ctrl+Q” 组 合 键 ) ，XOFF 采 用 ASCII 字 


守 集中 的 控制 字符 DC3 (十 进 制 值 为 19， 十 六 进 制 值 为 13， 相 当 于 按 
下 “Ctrl+S” 组 合 键 ) 。 在 一 次 数据 传输 过 程 中 ，XOFF、XON 的 周期 可 


重复 多 次 ， 但 这 些 操作 对 用 户 来 说 是 透明 的 ， 也 就 古 说 用 户 不 用 管 


它 ， 设 备 会 目 动 操作 。 


许多 异步 数据 通信 和 软件 均 支 持 XON/XOFF 协 议 。 这 种 方案 也 可 用 
于 计算 机 向 打印 机 或 其 他 终端 设备 (如 Modem 的 串 行 通信 ) 发 送 字 
符 ， 在 这 种 情况 下 ， 打 印 机 或 终端 设备 中 的 控制 部 件 用 以 控制 字符 流 
量 。 如 我 们 在 通过 Modem 拨 号 连接 网 络 时 ， 采 用 的 就 是 这 种 流量 控制 
方法 。 当 从 PC 机 上 的 数据 到 达 Modem 时 ， 如 果 Modem 中 的 缓存 空间 满 
了 ， 它 束 会 同 PC 机 发 送 一 个 代表 “ 俘 止 传输 ”的 XOFF 控 制 字符 ， 而 当 
Modem 中 的 缓存 空间 没 满 时 ，Modem 又 会 向 PC 机 传送 一 个 代表 “继续 


传输 ”的 XON 控 制 字符 。 


再 如 ， 在 局 域 网 中 一 台 PC 机 连接 了 一 台 打 印 速度 比较 慢 的 打印 
机 ， 当 PC 机 开始 向 打印 机 发 送 要 打印 的 文件 时 ， 因 为 PC 机 的 数据 传输 
速率 非常 高 ， 有 许多 文件 打印 机 很 难 及 时 打印 。 此 时 打印 机 会 向 PC 机 
发 送 一 个 XOFF 字 符 来 通知 PC 机 ， 要 求 暂停 文件 的 发 送 。PC 机 上 的 软 
件 看 到 来 自打 印 机 的 XOFF 控 制 字 符 后 ， 就 会 暂停 文件 的 发 送 ， 而 当 
打印 机 中 排队 等 候 打 印 的 文件 打 完 了 ， 或 者 打印 得 差不多 了 时 ， 打 印 
机 又 会 同 PC 机 发 送 一 个 XON 挖 制 字符 ， 通 知 PC 机 可 以 继续 发 送 要 打 
印 的 文件 。 


5.4.2 ”请 芒 窗 口 机 制 


在 上 面 介 绍 的 XONXOFF 流 量 控制 方案 中 ， 为 了 实现 发 送 端 与 接 
收 端的 速率 匹配 ， 需 要 往返 发 送 一 些 特殊 的 控制 字符 ， 这 样 束 会 使 得 
言 道 的 利用 率 大 打折 扣 ， 其 主要 是 用 于 与 一 些 低 数 据 处 理 能 力 的 接收 
端 通信 时 采用 。 在 实际 的 数据 链 路 层 流 量 控 制 中 ， 更 多 的 是 采用 本 六 
将 要 介绍 的 “滑动 窗口 机 制 * 来 进行 流量 控制 的 (传输 层 也 有 这 样 的 流 
量 控制 方案 ， 具 体 将 在 第 10 章 介绍 ) 。 

1. 理 解 “ 请 动 窗口 "机制 

“请 动 窗口 机 制 ? 中 的 “窗口 ?是 指 发 送 端 和 接收 端的 缓存 空间 大 
小 : “滑动 "的 意思 是 指 缓存 空间 中 存放 的 未 处 理 帧 数 是 变化 的 ， 发 送 


端 在 收 到 确认 帧 后 会 删除 原来 保存 在 缓存 中 的 待 重 发 帧 ， 而 接收 端 问 
网 络 层 提 交 一 个 帧 后 也 会 删除 原来 保存 在 绥 存 中 的 巾 。 


至 于 绥 存 空间 大 小 ， 采 取 不 同 的 流量 控制 方案 其 会 有 不 同 的 值 ， 
但 要 明日 的 是 ， 缓 存 空间 都 是 非常 有 限 的 ， 束 像 计算 机 CPU 中 的 缓存 
一 样 。 缓 存 越 大 ， 成 本 越 高 。 如 在 5.3.4 世 介绍 的 空闲 重 发 请 求 方案 
中 ， 一 次 只 能 发 送 一 个 帆 ， 发 完 一 个 帆 后 束 等 竺 来 目 接收 端的 确认 
帧 ， 收 到 确认 上 帆 后 吏 删 除 原 来 剑 存 在 缓存 空间 中 的 竺 重 发 帧 ， 接 收 站 
不 需要 缓存 空间 ， 因 为 它 接收 到 数据 后 即 进行 处 理 ， 对 于 有 错误 的 帧 


直接 丢弃 。 所 以 在 “空间 重 发 请 求 ”方案 中 仅 发 送 妆 需 要 保存 一 个 帧 的 
绥 存 空间 ， 也 丈 是 它 的 “缓存 空间 大 小 ” 束 古 一 个 帧 。 


而 在 前 面 介绍 的 “连续 重 发 请 求 ” 方 案 中 ， 发 送 闹 一 次 可 以 连续 发 
送 多 个 巾 ， 并 且 在 其 缓存 空间 中 保存 所 有 已 发 ， 但 没有 接收 到 来 日 接 
收 端 确认 帧 的 待 重 发 巾 ， 而 不 用 像 “ 空 几 重 发 请 求 ”那样 发 一 帧 停 下 来 
等 待 接收 闹 的 确认 帆 ， 接 收 问 也 可 以 在 缓存 空间 中 保存 来 不 及 处 理 的 
帧 ， 大 大 提高 了 数据 传输 的 效率 。 


同样 打 个 简单 的 比喻 来 说 。 就 像 一 个 水 缸 搂 了 大 小 两 个 不 同 口径 
的 水 管 ， 进 水 管 的 口径 较 大 ， 出 水 管 的 口径 较 小 。 在 这 样 的 情况 下 ， 
进 水 管 肯定 不 能 持续 不 断 地 向 水 缸 中 加 水 ， 否 则 就 会 因 出 水 速率 不 匹 
配 导致 水 从 水 缸 中 流出 来 了 。 所 以 通常 是 进 水 管 供 了 一 段 时 间 的 水 后 
就 要 停 下 来 ， 等 水 缸 中 的 水 用 得 差不多 了 再 加 水 。 这 时 水 缸 的 容量 就 
相当 于 上 面 所 说 的 接收 端 缓存 空间 大 小 了 。 


这 里 涉及 一 个 非常 重要 的 问题 ， 那 束 旦 到 展 一 次 最 多 连续 发 多 少 
个 蚌 比 较 合 适 呢 ? 这 里 要 考虑 两 方面 的 因素 ， 一 是 要 能 实现 有 效 的 郑 
错 控制 ， 二 是 要 与 接收 端的 数据 处 理 能 力 相 匹配 ， 前 者 我 们 已 介绍 ， 
本 市 仅 从 后 者 来 考虑 ， 也 就 是 从 流量 控制 角度 来 考虑 。 绥 存 空间 大 小 
又 与 帧 编号 有 关 ， 因 为 在 数据 传输 时 ， 每 个 帧 都 是 有 序列 号 的 ， 这 在 
本 章 前 面 介 绍 “ 兰 错 控 制 " 方 案 中 就 已 说 到 。 缓 存 空 间 越 大 ， 用 于 帧 编 
号 的 位 数 就 要 越 多 ， 如 1 位 可 以 表示 2 个 帧 〈 也 就 是 窗口 大 小 为 2) ，2 


位 可 以 表示 4 个 帧 (也 束 是 窗口 大 小 为 4) ，3 位 可 以 表示 8 个 帧 《也 就 
是 窗口 大 小 为 8) ，.……. ° 但 用 于 指示 帧 序列 号 的 位 数 越 多 ， 帧 的 无 用 
开销 就 越 大 ， 所 以 在 一 般 的 数据 链 路 层 协议 中 只 有 2 位 用 于 帧 编号 。 


2. 滑 动 窗口 实例 


在 此 以 1 位 帧 序列 号 ， 也 就 是 窗口 大 小 为 2 的 示例 来 介绍 “请 动 窗口 
机 制 ”。 下 面 从 初始 状态 开始 介绍 整个 流程 〈 注 意 ， 这 里 仅 考虑 正常 伟 
输 情 况 ， 不 考虑 出 现 差 错 的 情况 ) ， 如 图 5-14 所 示 〈 各 步 对 应 图 中 的 相 
应 序号 ) 


人 只 ot 个 帧 (2 号 帧 )， 待 重 发 帧 ， 并 从 个 由 (3 3 坑 ) 
号 帧 )， 并 保存 个 帧 (1 号 帧 ), 等 待 来 自 接收 端 余 该 待 重 发 帧 上 7 和 发 帧 ， 

在 缓存 中 pe 并 从 重 发 表 中 请、 并 保存 在 缓存 中 重 发 表 中 清除 帧 并 保存 在 组 存 4 i 中 请 
除 帧 序号 0 2 1 除 由 序号 2 


> Ey 收 到 0 号 帧 ， 并 把 收 到 的 0 号 帧 “ 收 到 1 号 帧 ， 并 把 收 到 的 1 3 帧 收 到 2 号 帧 ， 并 “把 收 到 的 2 号 帧 

帧 ， 缓 在 中 也 没 帧 ， 缓 在 中 也 没 ”向 发 送 端 发 送 0 提交 给 网 络 层 ， 向 发 送 端 发 送 1 提 交 给 网 络 层 ， 向 发 送 端 发 送 2 ”提交 给 网 络 层 ， 

有 任何 帧 有 任何 帧 号 确认 帧 然后 从 缓存 中 清 “ 号 确认 帧 然后 从 缓存 中 清 “号 确认 帧 然后 从 缓存 中 清 
除 该 帧 除 该 由 除 该 帧 


\ 
5 2) 


WB } 确认 ee 收 到 2 号 确认 
Pi 该 帧 ， 从 级 存 中 清 
: i 


继续 发 送 第 三 帧 ， 继续 发 送 第 四 


图 5-14 “请 动 窗口 机 制 ? 工 作 流程 示例 


1) 在 初始 状态 下 ， 发 送 端 和 接收 端的 缓存 空间 中 均 没 有 保存 数据 
帧 。 


2) 发 送 端 开 始 发 送 第 一 个 帧 一 0 号 帧 ， 并 把 它 保存 在 缓存 空间 
中 ， 并 建立 一 个 待 重 发 表 ， 第 一 个 巾 号 就 是 “0”。 


3) 因为 是 1 个 比特 位 用 于 帧 编号 ， 窗 口 大 小 为 2， 所 以 发 送 端 还 可 
以 继续 发 送 第 二 个 帧 一 一 1 号 帧 。 同 时 把 这 个 帧 保存 在 缓存 空间 中 ， 并 
向 待 重 发 表 中 添加 第 二 个 帧 的 序号 *1”。 此 时 因为 在 发 送 端的 缓存 空间 
中 已 保存 了 两 个 帧 〈0 号 帧 和 1 号 帧 ) ， 达 到 了 窗口 大 小 的 值 ， 不 能 继 
续 发 送 后 面 的 帧 了 ， 先 停 下 来 等 竺 来 目 接收 端的 确认 帧 。 在 等 待 的 过 
程 中 ， 接 收 问 可 能 收 到 了 0 号 巾 ， 然 后 同 发 送 端 返回 0 号 帧 的 确认 请 


自 。 


/JU 


4) 发 送 端 在 收 到 0 号 帧 的 确认 帧 后 ， 立 即 从 缓存 空间 中 清除 原来 
保存 的 0 号 待 重 发 帧 ， 并 在 待 重 发 表 中 清除 帧 序号 "0"， 接 收 端 把 收 到 
的 0 号 帧 提交 给 网 络 层 ， 并 清除 缓存 空间 中 的 0 号 帧 ， 此 时 缓存 空间 中 
又 为 空 了 。 


5) 此 时 发 送 端 继续 发 送 第 三 个 帧 一 一 2 号 帧 ， 同 时 也 把 这 个 帧 保 
存在 缓存 空间 中 ， 并 向 待 重 发 表 中 添加 第 三 个 帧 的 序号 “2”。 因 为 此 时 
发 送 端的 缓存 空间 中 又 已 保存 了 两 个 帧 〈1 号 帧 和 2 号 帧 ) ， 又 达到 了 
窗口 大 小 的 值 ， 不 能 继续 发 送 后 面 的 帧 了 ， 要 再 先 停 下 来 等 待 来 自 接 
收 咽 的 确认 帧 。 在 等 等 的 过 程 中 ， 接 收 端 可 能 义 收 到 了 1 号 帧 ， 然 后 癌 
发 送 首 返 回 1 号 帧 的 确认 帧 。 


6) 发 送 端 在 收 到 1 号 帧 的 确认 帧 后 ， 立 即 从 缓存 空间 中 清除 原来 
保存 的 1 号 待 重 发 帧 ， 并 在 竺 重 发 表 中 清除 帧 序号 “1”。 接 收 端 把 收 到 


的 1 号 帧 提交 给 网 络 层 ， 清 除 缓存 空间 中 的 1 号 帧 ， 此 时 缓存 空间 中 又 
为 空 了 。 


7) 此 时 发 送 端 继续 发 送 第 四 个 帧 一 一 3 号 帧 ， 同 时 也 把 这 个 帧 保 
存在 缓存 空间 中 ， 并 向 待 重 发 表 中 添加 第 四 个 帧 的 序号 “3”。 同 样 ， 
为 此 时 发 送 端的 缓存 空间 中 又 已 保存 了 两 个 帧 《1 号 帧 和 2 号 帧 ) ， 又 
达到 了 窗口 大 小 的 值 ， 不 能 继续 发 送 后 面 的 帧 了 ， 再 要 先 停 下 来 等 待 
来 日 接收 端的 确认 帆 。 在 等 得 的 过 程 中 ， 接 收 闪 可 能 又 收 到 了 2 号 帧 ， 
然后 向 发 送 返回 2 号 帧 的 确认 帧 。 


8) 发 送 端 在 收 到 2 号 帧 的 确认 帧 后 ， 立 即 从 缓存 空间 中 清除 原来 
保存 的 2 号 待 重 发 帧 ， 并 在 竺 重 发 表 中 清除 帧 序号 “2”。 接 收 端 把 收 到 
的 2 号 帧 提交 给 网 络 层 ， 清 除 缓存 空间 中 的 2 号 帧 ， 此 时 缓存 空间 中 又 


后 面 的 步 又 按照 以 上 流程 类 推 。 


说 明 ”数据 链 路 层 中 常见 的 协议 可 分 为 两 大 类 : 面向 字符 的 链 路 
层 协 议和 面向 比特 的 链 路 层 协议 (这 些 都 属于 同步 传输 模式 协议 ) 。 
面向 字符 的 链 路 层 协议 主要 有 IBM BSC (Binary Synchronous 
Communication， 二 进 制 同步 通信 ) 协议 、DEC DDCMP (Digital Data 


Communications Message Protocol， 数 字数 据 通 信 消 息 协议 ) 、SLIP 


(Serial Line Internet Protocol， 串 行 线路 网 际 协议 ) 、PPP (Point-to- 
Point Protocol， 点 对 点 协议 ) 等 ;面向 比特 的 链 路 层 协 议 主 要 有 IBM 的 
SDLC、ANSI 通 过 修改 SDLC 而 提出 的 ADCCP (Advanced Data 
Communication Control Procedure， 高 级 数据 通信 控制 规程 ) 、ISO 通 过 
修改 SDLC 而 提出 HDLC (High-level Data Link Control， 高 级 数据 链 路 
控制 ) 、CCITT 通 过 修改 HDLC 而 提出 LAP (Link Access Procedure， 链 
路 访问 规程 ) 等 。 下 面 将 介绍 儿 种 典型 的 数据 链 路 层 协议 。 


5.5 面 问 字符 的 BSC 协 议 


面 癌 字符 的 同步 方法 也 称 “ 字 符 填 充 的 首尾 定 界 符 法 ”。 在 该 同步 
方法 中 ， 数 据 帧 中 的 数据 都 被 看 作 字符 序列 (所 以 称 之 为 面向 字符 的 
同步 传输 ) ， 所 有 的 控制 信息 也 都 是 字符 形式 (当然 数据 的 表示 形式 
还 是 二 进 制 的 比特 流 ) ， 每 个 数据 块 的 头 部 用 一 个 或 多 个 同步 字符 
SYN 来 标记 数据 块 的 开始 ;尾部 用 字符 ETX 来 标记 数据 决 的 结 


面向 字符 的 同步 传输 协议 的 典型 代表 就 是 IBM 公 司 的 BSC 协 议 。 
BSC 协 议 规定 ， 链 路 上 传送 的 数据 必须 是 由 规定 字符 集 (可 以 是 
ASCII， 或 者 EBCDIC (Extended Binary Coded Decimal Interchange 
Code， 扩 展 二 进 制 -十 进 制 交换 码 ) ) 中 的 字符 组 成 ， 控 制 信息 也 必须 
由 同一 个 字符 集中 的 看 干 指定 的 控制 字符 构成 。 


5.5.1 ”BSC 控制 学 符 和 数据 块 结 构 


BSC 协 议 与 所 有 同步 传输 协议 一 样 ， 也 是 一 次 可 以 传送 由 耕 干 个 
字符 组 成 的 数据 块 (通常 是 一 巾 ) ， 而 不 是 一 次 只 传送 一 个 字符 。 同 
时 规定 了 十 种 特殊 字符 〈《 称 为 通信 控制 字符 ) 作为 这 个 数据 块 的 开始 
与 结束 标志 ， 以 及 整个 传输 过 程 的 各 种 控制 信息 标志 (并 不 是 每 个 数 


据 块 中 都 有 这 十 种 全 部 的 控制 字符 ) 。 这 十 种 通信 控制 字符 说 明 如 
下 


DACK (Acknowledge) : 确认 标志 ， 由 接收 端 发 出 的 ， 作 为 对 正 
确 接收 到 报 文 的 响应 。 


DDLE (Data Link Escape) : 转 义 标志 ， 用 于 指示 后 面 的 字符 是 
数据 字符 ， 而 不 是 特殊 控制 字符 。 这 是 用 来 进行 透明 传输 的 ， 当 在 报 
文中 也 存在 这 十 个 控制 字符 时 ， 在 这 些 字符 前 加 上 DLE 字 符 后 ， 通 知 
接收 端 把 它们 当 作 普 通 的 报 文 处 理 ， 而 不 是 作为 控制 字符 来 识别 。 有 具 
体 将 在 本 市 后 面 介绍 。 


DENQ (Enquire) : 询问 标志 ， 用 于 请 求 远程 站 点 给 出 响应 。 响 
应 可 能 包括 远程 站 点 的 号 份 或 状态 。 


DEOT (End of Transmission) : 发 送 完毕 标志 ， 用 于 表示 一 个 或 
多 个 文本 的 发 送 结束 ， 并 拆除 链 路 。 


DETB (End of transmission Block) : 块 终止 或 组 终止 标志 ， 用 于 
标志 每 个 数据 块 的 结束 位 置 。 仅 在 一 个 报 文 要 分 成 多 个 数据 块 传输 时 
才 有 此 标志 。 


DETX (End of Text) : 文本 终止 标志 ， 标 志 报 文 文本 的 结束 。 仅 
在 一 个 报 文 不 分 成 多 个 数据 块 传输 时 才 有 此 标志 。 


DNAK (Negative Acknowledge) : 否认 标志 ， 由 接收 端 发 出 的 ， 
作为 对 未 正确 接收 的 报 文 啊 应 。 


口 SOH (Start of Head) : 报头 开始 标志 ， 用 于 表示 报 文 的 标题 信 
息 或 报头 的 开始 。 仪 在 报 文 的 第 一 个 数据 块 中 才 有 此 标志 。 


口 STX (Start of Test) : 文本 开始 标志 ， 标 志 标 题 信息 的 结束 和 报 
文 文本 的 开始 。 每 个 数据 块 均 有 此 标志 。 


口 SYN (Synchronous) : 字符 同步 标志 ， 用 以 实现 通信 双方 的 字 
符 同 步 ， 或 用 于 在 无 数据 传输 时 保持 同步 。 在 每 个 数据 块 中 均 有 此 标 


志 ， 而 且 通 稼 是 两 个 。 


以 上 这 十 种 通信 控制 字符 所 对 应 的 ASCII 码 (ASCII 中 是 用 低 7 位 表 
示 一 个 字符 的 ， 最 高 位 为 校 验 码 ) 或 EBCDIC 码 值 如 表 5-3 所 示 。 这 些 
控制 字符 代码 所 对 应 的 ASCII 也 可 参见 图 4-7。 这 种 通信 控制 字符 中 ， 
在 数据 同步 传输 中 起 关键 作用 的 就 是 SYN、SOH、STX 、ETB、ETX、 


EOT 这 六 种 通信 控制 字符 。 


表 5-3 BSC 协议 十 种 通信 控制 字符 对 应 的 代码 


控制 字符 名 称 对 应 的 EBCDIC 码 


NAK 0010101 00111101 


通过 前 面 的 介绍 可 以 知道 ， 根 据 同 步 传输 中 报 文 在 数据 块 中 所 处 
的 位 置 不 同 ，BSC 协 议 的 数据 块 有 所 不 同 ， 有 具体 有 如 下 四 种 格式 。 


口 不 帝 报 头 的 单 块 报 文 或 分 块 传输 中 的 最 后 一 块 报 文 的 格式 为 : 


SN | sw | srx 报 文 | ETX BCC 
口 市 报头 的 单 块 报 文 的 格式 为 : 

SN | SIN | 508 SR ER | Bcc 
口 分 块 传输 中 的 第 一 块 报 文 的 格式 为 : 

SYN | SN | son | 报 X | Sx | RX | EB | Bcc 


口 分 块 传输 中 的 中 间 报 文 的 格式 为 : 


SYN | SYN | STX 报 文 ETB BCC 


从 以 上 四 种 数据 报 文 格式 中 可 以 得 出 BSC 报 文 传输 的 如 下 两 个 基 
本 特点 : (DBSC 协 议 中 所 有 发 送 的 数据 均 跟 在 至 少 两 个 SYN 字 符 之 后 ， 
以 使 接收 端 能 实现 字符 同步 ， (所 有 数据 块 在 块 终止 标志 符 (ETX 或 
ETB) 之 后 还 有 块 校 验 字符 BCC (Block Check Character) ， 校 验 是 
字 节 的 CRC (循环 校 验 码 ) 或 双 字 忆 的 CRC， 校 验 范 围 从 STX 开 始 到 
ETX 或 ETB 为 止 。 


5.5.2 BSC 协议 数据 透明 传输 原理 


面向 字符 的 同步 传输 协议 不 像 异步 传输 协议 那样 需要 在 每 个 字符 
前 后 附加 起 始 和 停止 位 ， 因 此 传输 效率 提高 了 。 但 由 于 采用 了 一 些 特 
殊 的 传输 控制 字符 ， 在 增强 了 通信 控制 能 力 和 校 难 功能 的 同时 也 市 来 
了 新 的 问题 ， 那 惑 是 如 何 区 别 数据 字符 代码 和 特殊 控制 字符 代码 。 因 
为 在 数据 块 中 完全 有 可 能 出 现 与 特殊 控制 字符 代码 相同 的 数据 字符 ， 
这 就 会 在 接收 端 产生 误解 。 比 如 正文 有 个 与 终 目 字符 ETX 的 代码 相同 
(在 ASCII 码 中 为 0000011) 的 数据 字符 ， 如 果 不 做 任何 处 理 ， 接 收 端 
就 不 会 把 它 当 作 普 通 数 据 处 理 ， 而 误 认 为 是 正文 结束 ， 进 而 产生 差 
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为 此 解决 这 一 问题 ， 面 向 字符 的 同步 传输 协议 应 具有 将 数据 块 中 
的 特殊 字符 作为 普通 数据 处 理 的 能 力 ， 这 种 能 力 称 为 数据 透明 。 解 决 
方案 是 在 同步 传输 协议 中 设置 转 义 字符 DLE (Data Link Escape， 数 据 
链 路 封装 ) 。 当 需要 在 数据 块 中 传输 一 个 与 某 个 特殊 字符 代码 一 样 的 
数据 时 ， 就 要 先 在 它 前 面 要 加 一 个 DLE 代 码 (ASCII 码 中 为 
0010000) ， 这 样 接收 端 在 收 到 一 个 DLE 代 码 时 ， 就 知道 了 它 下 面 一 个 
字符 是 普通 的 数据 字符 ， 而 不 是 通信 控制 字符 。 在 接收 端 如 果 发 现 一 
个 与 某 个 特殊 字符 代码 相同 的 字符 是 DLE 代 码 ， 则 直接 删除 前 面 的 
DLE 代 码 ， 仅 接收 真实 的 数据 部 分 。 


如 要 在 数据 中 传输 EOT 字 符 ， 为 了 避免 把 它 误 认为 是 通信 控制 字 
符 ， 就 是 需 移 键 入 一 个 DLE 字 符 ， 然 后 再 键入 EOT 字 符 ， 如 图 5-15a 所 
示 。 在 接收 端 会 直接 删除 EOT 字 符 代 码 前 面 的 DLE 代 码 ， 仅 接收 数据 
部 分 的 EOT 代 码 。 


同样 ， 当 要 传输 的 数据 中 有 一 个 代码 与 DLE 的 数据 字符 相同 时 ， 
也 要 先 在 它 前 面 加 上 另外 一 个 DLE 字 符 ， 相 当 于 要 传输 一 个 普通 的 
DLE 数 据 字 符 ， 即 需要 键入 两 个 "DLE” 字 符 ， 如 图 5-15b 所 示 。 在 接收 
端 如 果 发 现 有 连续 两 个 DLE 字 符 ， 则 直接 删除 前 面 那 个 DLE 字 符 ， 仅 
接收 后 面 一 个 作为 数据 的 DLE 字 符 。 


a ) 当 在 数据 中 要 传输 “EOT” 字 符 时 


b ) 当 在 数据 中 要 传输 “DLE” 字 符 时 
图 5-15 两 个 数据 透明 传输 示例 


从 以 上 可 以 看 出 ， 这 种 面 癌 字符 的 同步 方法 实现 起 来 相当 麻烦 ， 
因为 BSC 这 类 同步 传输 协议 中 的 控制 字符 本 吴 比 较 多 ， 很 容易 束 造 成 
了 与 数据 中 传输 数据 代码 的 冲突 。 也 正 是 因为 这 个 缺 操 ， 后 面 义 产生 
了 下 市 将 要 介绍 的 面向 比特 的 同步 传输 协议 。 


5.6 ”面向 比特 的 SDLC 和 HDLC 协 议 


面向 比特 的 同步 传输 协议 中 ， 数 据 块 是 作为 比特 流 来 处 理 的 (而 
不 是 作为 字符 流 来 处 理 ) ， 所 以 称 之 为 面向 比特 的 同步 传输 。 在 面向 
比特 的 同步 传输 中 ， 每 个 数据 块 的 头 部 和 尾部 都 用 一 个 特殊 的 比特 序 
列 (如 01111110) 来 标记 数据 块 的 开始 和 结束 ， 这 就 是 面 癌 比特 的 同步 
传输 协议 中 的 基本 成 帧 原理 ， 或 者 说 是 基本 的 帧 同步 原理 。 在 局 域 网 
中 所 采用 的 传输 方式 都 是 面向 位 流 的 同步 传输 方式 ， 由 它们 各 目的 介 
质 访问 控制 协议 来 定义 具体 的 数据 格式 〈 即 帧 格式 ) 以 及 相应 的 介质 
访问 控制 方法 。 


面向 比特 同步 传输 的 通信 协议 中 ， 最 具有 代表 性 的 是 IBM 的 SDLC 
(Synchronous Data Link Control， 同 步 数 据 链 路 控制 ) 协议 、 国 际 标准 
化 组 织 ISO 的 HDLC 协 议 ， 美 国 国家 标准 协会 ANSI 的 ADCCP 。 


SDLC 协 议 是 一 种 IBM 数 据 链 路 层 协议 ， 适 用 于 系统 网 络 体系 结构 
(SNA) ; HDLC 是 一 种 在 同步 网 上 传输 数据 、 面 向 位 的 数据 链 路 层 协 
议 ， 是 ISO 对 IBM 的 SDLC 协 议 进 行 了 改进 和 标准 化 的 协议 。 但 是 SDLC 
属于 单 链 路 规程 ， 而 HDLC 属 于 多 链 路 规程 。 所 有 面向 比特 的 数据 链 路 
控制 (DLC) 协议 均 采 用 统一 的 帧 格式 ， 且 不 论 是 数据 还 是 单独 的 控 
制 信息 均 以 帧 为 单位 传送 。 


SDLC 文 持 识别 两 类 网 络 站 点 : 主 站 点 (Primary Station) 和 从 站 点 
(Secondary Station) 。 主 站 点 控制 从 站 点 ， 主 站 点 轮 询 从 站 点 是 否 有 
数据 要 发 送 。 也 就 是 说 ， 从 站 点 只 有 在 主 站 点 授权 前 提 下 才 可 以 向 主 
站 点 发 送信 息 ， 如 果 一 个 从 站 点 有 数据 要 发 送 ， 当 它 被 主 站 点 识别 后 
才 可 开始 数据 传输 。 主 站 点 按照 预先 确定 的 顺序 选择 从 站 点 ， 一 旦 选 
定 的 从 站 点 已 经 导入 数据 ， 那 么 它 即 可 进行 数 传输 。 同 时 主 站 点 可 以 
建立 和 拆除 链 路 ， 并 在 运行 过 程 中 控制 这 些 链 路 。 


5.6.1 HDLC 链 路 结构 和 探 作 方 式 


HDLC 有 是 也 采用 主 站 点 和 从 站 点 操作 方式 。 在 链 路 上 起 控制 作用 的 
站 点 称 为 主 站 点 ， 其 他 的 受 主 站 控制 的 站 点 称 为 从 站 点 。 主 站 点 负责 
对 数据 流 进行 组 织 ， 并 且 对 链 路 上 的 差错 实施 恢复 。 由 主 站 点 发 往 从 
站 扩 的 巾 称 为 命令 巾 ， 而 由 从 站 后 返回 主 站 后 的 巾 称 为 啊 应 巾 。 连 有 
多 个 站 点 的 链 路 通 闸 使 用 查询 技术 ， 对 其 他 站 后 进行 查询 的 站 点 称 大 
主 站 点 ， 而 在 点 到 点 链 路 中 每 个 站 点 均 可 作为 主 站 点 。 主 站 需要 比 从 
站 点 有 更 多 的 功能 ， 所 以 当 终 端 与 主机 相连 时 ， 主 机 一 般 总 是 主 站 
点 ; 在 一 个 站 点 连 接 多 条 链 路 的 情况 下 ， 该 站 点 对 于 一 些 链 路 而 言 可 
能 是 主 站 点 ， 而 对 男 外 一 些 链 路 而 言 又 可 能 是 从 站 点 。 


在 HDLC 中 ， 对 主 站 点 、 从 站 点 和 复合 站 点 定义 了 图 5-16 所 示 的 二 
种 链 路 结构 ， 不 平衡 链 路 结构 、 对 称 非 平 衡 链 路 结构 和 平衡 链 路 结 


构 。 从 图 中 可 以 看 出 ， 不 同 链 路 结构 ， 人 允许 的 站 点 的 类 型 以 及 各 站 点 
发 送 命令 帧 和 了 啊 应 帧 的 权限 也 不 一 样 。 


应 答 帧 

主 站 点 主 站 点 

命令 帧 从 站 点 命令 帧 

一 一 全 

从 站 点 
a) 不 平衡 链 路 结构 
站 点 从 站 点 
复合 站 点 复合 站 点 


命令 帧 / 应 答 帧 


-| 一 
命令 帧 / 应 答 帧 


c) 平衡 链 路 结构 


和 


、 
> 帧 / oie 


b) 对 称 不 平衡 链 路 结构 
图 5-16 HDLC 的 三 种 链 路 结构 


根据 通信 双方 的 链 路 结构 和 传输 响应 类 型 ，HDLC 提 供 了 三 种 操作 
方式 ， 正 常 响应 方式 、 异 步 响 应 方式 和 异步 平衡 方式 。 


1. 正 第 啊 应 方式 


正 汕 啊 应 方式 (NRM) 适用 于 不 平衡 链 路 结构 ， 主 要 用 于 点 对 点 
和 一 点 对 多 点 的 链 路 结构 中 ， 竺 别 是 一 点 对 多 点 链 路 ， 一 端 为 主 站 
扎 ， 另 一 端 为 从 站 点 ， 如 图 5-16a 所 示 “。 在 这 种 方式 中 ， 主 站 点 控制 着 


# 


整个 链 路 的 操作 ， 有 负责 链 路 的 初始 化 、 数 据 流 控制 和 链 路 复位 等 ， 而 
从 问 护 仅 可 在 收 到 主 站 点 的 明确 允许 后 ， 才 能 发 出 啊 应 ， 所 以 它们 的 
角色 是 不 对 称 的 ， 也 束 是 不 平衡 的 。 


2. 异 步 啊 应 方式 


异步 响应 方式 (ARM) 也 适用 于 不 平衡 链 路 结构 ， 它 一 般 是 对 称 
不 平衡 链 路 结构 ， 如 图 5-16b 所 示 。ARM 与 NRM 不 同 的 是 : 在 ARM 
中 ， 从 站 点 可 以 在 没有 得 到 主 站 点 允许 的 情况 下 开始 数据 传输 ， 所 以 
它 的 传输 效率 比 NRM 高 。 


3. 异 步 平 衡 方式 


异步 平衡 方式 (ABM) 适用 于 平衡 链 路 结构 ， 即 链 路 两 端 都 是 复 
合 站 点 ， 也 就 是 该 站 点 既 可 作为 主 站 点 ， 又 可 作为 从 站 点 ， 如 图 5-16c 
所 示 。 在 这 种 链 路 结构 中 ， 两 闯 的 复合 站 点 具有 同等 的 能 力 ， 不 管 哪 
个 复合 站 点 均 可 在 任意 时 间 发 送 命令 帧 ， 并 且 不 需要 收 到 对 方 复 合 站 
点 发 出 的 命令 帧 歼 可 以 发 送 啊 应 帧 。ITU 一 TX.25 建 议 的 数据 链 路 层 就 
采用 这 种 方式 。 


除了 以 上 三 种 基本 操作 方式 外 ，HDLC 还 有 三 种 扩充 方式 ， 即 扩充 
正常 响应 方式 (SNRM) 、 扩 充 异步 响应 方式 (SARM) 、 扩 充 异 步 平 
衡 方式 (SABM) ， 它 们 分 别 与 基本 方式 相对 应 。 


5.6.2” SDLC/HDLC 帧 结构 


下 面 以 SDLC 和 HDLC 协 议 为 例 介绍 面向 比特 的 同步 传输 协议 的 数 
据 帧 格式 ， 如 图 5-17 所 示 。 各 字段 的 说 明 如 下 : 


pai 全 站 -2 字 节 | 字 节 -六 一 一 一 可 变 ee 本 二 


图 5-17 SDLC/HDLC 帧 格式 


标志 地 址 


1. 标 志 字 段 


SDLC/HDLC 协 议 规定 ， 所 有 信息 传输 必须 以 一 个 “标志 ”字段 F 
(Flag) 开始 ， 且 以 同一 个 标志 字段 结束 。 也 就 是 说 每 帧 数据 中 有 两 个 
标志 字段 ， 值 均 为 01111110 (在 EBCDIC 码 中 是 “=” 字 符 ) ， 占 1 字 节 。 
标志 字段 用 于 界定 不 同 帧 ， 以 获得 帧 边界 ， 实 现 通信 双方 的 帧 同步 ， 
因为 接收 端 可 以 通过 搜索 “01111110” 来 获知 帧 的 开头 和 结束 。 通 常 ， 在 
不 进行 帧 传送 的 时 刻 ， 为 了 维持 信道 处 于 激活 状态 ， 发 送 端 会 不 断 地 
发 送 标志 字段 ， 使 接收 端 认 为 一 个 新 的 帧 传送 已 经 开始 。 


SDLC/HDLC 中 使 用 标志 字段 的 方法 可 以 是 一 个 帧 包括 一 个 开始 标 
志和 一 个 结束 标志 (如 图 5-18a 所 示 ) ， 也 可 以 把 一 个 帧 的 结束 标志 当 
成 下 一 个 帧 的 开始 标志 ， 也 就 是 共享 标志 字段 (如 图 5-18b 所 示 ) ， 还 


可 以 把 一 个 帧 的 结束 标志 中 的 最 后 一 个 “0? 当 成 下 一 帧 开始 标志 的 第 一 
个 “0” (如 图 5-18c 所 示 ) 。 


开始 标志 结束 标志 


01111110 地 址 控制 信息 FCC 01111110 
a) 
第 n 帧 第 n+1 帧 


A 


01111110 地 址 控制 信息 FCC 01111110 地 址 控制 信息 FCC 01111110 


第 n 帧 的 结束 标志 与 第 n+1 
帧 中 的 开始 标志 共享 
b ) 
01111110 地 址 控制 信息 FCC 011111101111110 地 址 控制 信息 FCC 01111110 


第 n 巾 。 _ ， 第 n+1 帧 
第 m 报 第 i 帧 结束 标志 中 最 后 一 个 “0 
与 篇 n+1 帧 中 开始 标志 中 的 第 一 


从 、 NN” > 下 了 
个 “0” 共 享 


c) 


图 5-18 SDLC/HDLC 协 议 标 志 字 上 段 的 三 种 实现 帧 同步 的 方法 


在 一 串 数 据 比特 中 ， 有 可 能 产生 与 标志 字段 的 码 型 相同 的 比特 组 
合 一 一 01111110。 为 了 防止 这 种 情况 发 生 ， 保 证 对 数据 的 透明 传输 ， 采 
取 了 比特 填充 技术 。 束 是 在 信和 号码 中 出 现 连续 5 个 “1” 以 后 插入 一 
个 “0”"， 如 图 5-19 所 示 。 在 接收 端 只 需要 再 去 控 5 个 “1” 后 面 插入 的 “0” 即 
可 恢复 原来 的 信号 码 序 列 。 


在 5 个 连续 “1” 
面 插入 一 个 a 


图 。 5-19 ”SDLC/HDLC 的 数据 透明 传输 示例 


2. 地 址 字段 


在 “标志 ”字段 之 后 是 一 个 “地 址 ”字段 A (Address) ， 表 明 帧 是 来 自 
主 站 点 还 是 来 自从 站 点 。 主 站 点 或 者 复合 站 点 发 送 的 命令 帧 中 地 址 字 
段 携带 的 是 对 方 从 站 点 的 地 址 ， 而 从 站 点 发 出 的 响应 帧 的 地 址 字段 携 
带 的 是 本 站 点 的 地 址 。 总 体 来 说 ， 在 使 用 不 平衡 方式 〈 包 括 NRM 和 
ARM) 传输 数据 时 ， 地 址 字段 总 是 写 入 从 站 的 地 址 ; 在 使 用 平衡 方式 
(ABM) 时 ， 地 址 字段 总 是 写 入 响应 站 点 的 地 址 。 


“地 址 ”字段 可 占 8 位 或 16 位 〈 也 就 是 1， 或 者 2 个 字 节 ) ， 通 常 是 采 
用 8 位 长 度 。00000000 的 地 址 为 空地 址 ， 不 能 分 配给 任何 站 点 ， 用 于 测 
斌 数据 链 路 的 状态 ;11111111 地 址 为 广播 地 址 ， 使 用 这 个 地 址 就 可 以 把 
一 个 数据 帧 发 送 到 同一 网 段 中 其 他 所 有 站 点 。 因 此 在 采用 8 位 地 址 格式 


时 ， 总 的 有 效 地 址 数 是 254 个 ， 这 对 一 般 的 多 点 链 路 来 说 是 足够 了 。 但 
考虑 在 某 些 情况 下 ， 例 如 使 用 分 组 无 线 网 ， 用 户 可 能 很 多 ， 可 使 用 扩 
充 地 址 字段 ， 以 字 世 为 单位 扩充 。 在 扩充 时 ， 每 个 地 址 字段 的 第 1 位 用 
作 扩 充 指示 ， 即 当 第 1 位 为 <0” 时， 表示 后 续 一 个 字 贡 为 扩充 地 址 子 
段 ， 当 第 1 位 为 “1" 时 ， 和 表示 后 续 一 个 字 节 不 是 扩充 地 址 字段 ， 地 址 字 
段 到 此 为 止 。 


3. 控 制 字 段 


“控制 ?字段 C (Control) 用 来 实现 HDLC 协 议 的 各 种 控制 信息 ， 并 
标志 是 否 是 数据 《因为 它 可 以 标志 不 同 的 帧 类 型 ) ， 占 1 个 字 节 长 度 。 
发 送 方 主 站 点 或 复合 站 点 利用 控制 字段 来 通知 被 寻 址 的 从 站 点 或 复合 
站 点 执行 约定 的 操作 ;而 从 站 点 用 该 字段 对 来 自主 站 点 或 复合 站 点 的 
命令 帧 进行 啊 应 ， 报 告 已 完成 的 操作 或 状态 的 变化 。 


“控制 ?字段 的 结构 如 网 5-20 所 示 ， 共 8 位 ， 根 据 其 最 前 面 两 个 比特 
的 取 值 ， 可 将 HDLC 帧 划分 为 三 大 类 ， 即 信息 帧 1 《Information) 、 监控 
帧 S (Supervisory) 和 无 编号 帧 U (Unnumbered) 。 如 果 控 制 字段 中 的 
第 1 位 为 0， 则 代表 发 送 的 是 项 ;如 采 欣 制 字 段 中 的 第 1 位 和 第 2 位 为 
10， 则 代表 发 送 的 征 $ 帆 ;如 采 控 制 字段 中 的 第 1 位 和 第 2 位 为 11， 则 代 
表 发 送 的 是 U 巾 。 有 关 这 三 种 帧 类 型 及 各 目的 “控制 "字段 具体 结构 ， 将 
在 本 节 后 面 介绍 。 


[由 


S 帧 


图 5-20 HDLC“ 控 制 " 字 段 结构 


人 


在 “控制 ”字段 结构 中 ， 最 难 理解 的 就 是 第 5 位 的 P/F (PolVFinal， 查 
询 /结束 ) 位 。 在 HDLC 的 各 类 帆 中 均 市 有 这 个 P/F 位 ， 但 在 不 同 帧 中 的 
含义 不 一 样 : 在 由 主 站 点 发 出 的 命令 帧 中 取 “P” 位 ， 起 查询 的 作用 ， 即 
当 该 位 为 1 时 ， 要 求 被 查询 的 从 站 点 做 出 响应 ; 在 从 站 点 响应 主 站 点 的 
帧 中 取 “F” 位 ， 起 结束 数据 发 送 或 确认 结束 的 作用 ， 即 当 该 位 为 1 时 ， 
表示 从 站 点 数据 发 送 完毕 ， 或 者 响应 完毕 。P/F 位 在 不 同 的 链 路 结构 操 
作 方 式 中 所 代表 的 含义 并 不 一 样 。 具 体 如 下 : 


在 NRM 方 式 中 ， 从 站 点 不 能 主动 同 主 站 上 后 发 送信 息 ， 从 站 上 后 只 有 
在 收 到 主 站 点 发 出 P 位 为 1 (表示 对 各 从 站 点 依次 进行 查询 ， 看 看 这 些 
从 站 点 是 否 有 数据 发 送 ) 的 命令 帧 以 后 才能 发 送 对 应 的 响应 帧 : 如 果 
从 站 点 有 数据 发 送 ， 则 在 最 后 一 个 帧 中 将 F 位 置 1 (表示 数据 发 送 结 
束 ) ， 中 间 的 项 F 位 置 0 (表示 数据 还 没 发 完 ) ; 如 果 从 站 点 无 数据 发 
送 ， 则 要 同 主 站 点 发 送 将 F 位 置 1 的 啊 应 帧 。 


在 ARM 或 ABM 方 式 中 ， 任 何 一 个 站 点 都 可 以 在 主动 发 送 的 S 帧 和 1 
帧 中 将 P 位 置 1 (同样 是 表示 对 各 从 站 点 或 者 对 方 复合 站 点 依次 进行 查 
询 ， 看 看 它们 是 否 有 数据 发 送 ) 。 对 方 站 点 在 收 到 P=1 的 S 帧 或 帕 后 ， 
同样 会 按照 上 面 介绍 的 方法 进行 处 理 : 如 果 对 方 站 点 有 数据 发 送 ， 则 
在 最 后 一 个 S 帧 或 帧 中 将 F 位 置 1 《表示 数据 发 送 结束 ) ， 中 间 的 S 帧 或 
帧 F 位 置 0 (表示 数据 还 没 发 完 ; 如 果 对 方 站 点 无 数据 发 送 ， 则 要 向 
主 站 点 发 送 将 F 位 置 1 的 响应 帧 。 


4. 信 息 字 段 


言 息 字 段 包 仿 了 用 户 的 数据 信息 和 来 自 上 层 的 各 种 控制 信息 。 在 I 
帧 和 某 些 U 帧 中 具有 该 字段 ， 且 可 以 是 任意 长 度 的 比特 序列 。 在 实际 应 
用 中 ， 其 长 度 由 收发 站 的 缓冲 器 的 大 小 和 线路 的 差错 情况 决定 ， 但 必 
须 是 8 位 的 整数 倍 。 该 字段 可 以 是 0 长 度 ， 也 就 是 可 以 无 信息 字段 ， 如 
在 监控 帧 (Ss 帧 ， 中 束 规 定 不 能 有 信息 字段 。 


5. 帧 校 验 序列 字段 


帧 校 验 序 列 (FCS) 字段 可 以 使 用 16 位 的 CRC， 对 两 个 标志 字段 之 
间 的 整个 帧 的 内 容 进 行 校 验 。CCITT 和 ISO 推荐 使 用 的 生成 多 项 式 为 
g(x)=xle +x1? +x? +1; IBM SDLC 使 用 的 生成 多 项 式 为 g(x)=x1 +x1? +x? 
+1。 有 关 CRC 的 校 验 原理 参见 5.3.2 廊 。 


由 于 在 SDLC/HDLC 的 帧 中 至 少 舍 有 A (地 址 ) 、C (控制 ) 和 FCS 
( 帆 校 验 序列 ) 这 三 个 字段 ， 所 以 整个 帧 长 度 最 小 为 32 位 。 


5.6.3 SDLC/HDLC 帧 类 型 及 其 标识 方法 


前 面 说 了 ， 在 SDLC 和 HDLC 等 数据 链 路 控制 协议 中 ， 有 I 巾 、s 帧 
和 UD 帜 三 种 帧 类 型 。 下 面具 体 介绍 这 些 类 型 巾 ， 以 及 在 控制 字段 中 如 何 


标志 它们 。 


1. 信 息 帆 (1 帧 ) 


I 帧 用 于 用 户 数据 传输 ， 包 含 信息 字段 。 在 项 控制 字段 中 第 1 位 固 
定 为 0， 第 2 位 ~ 第 4 位 为 N (S) ， 用 于 标志 要 发 送 的 帧 的 序号 ;第 5 位 为 
PAF 位 ;第 6 位 ~ 第 8 位 为 N (R) ， 用 于 标志 期 待 要 接收 的 帧 序号 ( 它 有 
两 层 含义 : 一 是 表示 发 送 端 已 确认 了 前 N-1 个 帧 ， 另 一 个 是 发 送 端 期 和 
送 第 N 帕 的 确认 帆 。) 


N (S) 和 N (R) 各 占 3 位 ， 即 序号 采用 模 8 运 算 ， 使 用 0~7 八 个 编 
号 。 在 有 些 场 合 ， 如 卫星 通信 中 ， 模 8 已 经 不 能 满足 要 求 了 ， 这 时 可 以 
把 控制 字段 扩展 为 2 字 节 ，N (S) 和 N (R) 都 可 用 7 位 来 表示 ， 即 增加 
到 模 128。 


2. 监 欣 帧 (S 帧 ) 


S 帆 用 于 监视 和 控制 数据 链 路 ， 完 成 项 的 接收 确认 、 重 发 请 求 、 
暂停 发 送 请 求 等 功能 。S 帧 没有 信息 字段 (一 共 只 有 48 位 ) ， 可 由 主 站 


点 或 从 站 点 发 送 ， 具 体 要 视 对 应 的 链 路 结构 操作 方式 。 在 S 帧 的 控制 字 
段 中 第 1 位 和 第 2 位 分 别 固 定 为 1、0; 第 3 位 和 第 4 位 为 S， 代 表 监 控 功 


能 ， 第 5 位 PF 和 第 6~8 位 与 着 一 样 。 


因为 用 于 表示 监控 功能 的 S 共 有 2 位 ， 所 以 可 以 代表 4 种 监控 类 型 的 
央 ， 具 体 如 下 : 


口 00 一 一 接收 就绪 (RR) ， 主 站 点 可 以 使 用 RR 型 S 帧 来 查询 从 站 
点 ， 即 希望 从 站 点 传输 控制 字段 中 第 6~8 位 N (R) 所 指示 的 编号 为 N 
(R) 的 项， 如 果 从 站 点 存在 这 样 的 帧 ， 便 进行 传输 。 从 站 点 也 可 用 
RR 型 $ 帆 来 作为 对 主 站 点 的 啊 应 央 ， 表 示 从 站 点 布 望 从 主 站 点 那里 接 
收 的 下 一 个 项 的 编号 是 N (R) 。 


口 01 一 一 拒绝 (REJ) ， 用 于 接收 端 要 求 发 送 端 对 从 编号 为 N 
(R) 开始 的 帧 及 其 以 后 所 有 的 帧 进行 重 发， 这 也 暗示 N (R) 以 前 的 I 
帧 已 被 正确 接收 。 


口 10 一 一 接收 未 就 绪 (RNR) ， 用 于 接收 端 通知 发 送 端 编 号 小 于 N 
(R) 的 项 已 被 收 到 ， 但 目前 正 处 于 忙 状态 ， 尚 未 准备 好 接收 编号 为 N 
(R) 的 其， 这 可 用 来 对 链 路 流量 进行 控制 。 


口 11 一 一 选择 拒绝 (SREJ) ， 用 于 接收 端 要 求 发 送 端 发 送 编号 为 N 
(R) 单个 其， 并 暗示 其 他 编号 的 ] 帆 已 全 部 确认 。 


上 面 四 种 s 帧 中 ， 前 三 种 用 在 回 退 N 帧 ARQ 方 案 中 ， 最 后 一 种 只 用 
于 选择 重 发 ARQ 方 式 中 。 有 关 这 两 种 差错 控制 方案 参见 5.3.5 节 。 


3. 无 编号 帧 (U 帧 ) 


U 幢 用 于 数据 链 路 的 控制 ， 不 带 编 号 ， 可 以 在 任何 需要 的 时 刻 发 
出 ， 而 不 影响 带 编号 的 信息 帧 的 交换 顺序 。 在 U 帧 的 “控制 * 字 段 中 第 1 
位 和 第 2 位 都 固定 为 1;， 第 3 位 和 第 4 位 ， 以 及 第 6~8 位 均 为 M， 代 表 无 编 
号 功能 ， 第 5 位 P/F 与 帧 一 样 。 


U 帧 可 以 分 为 命令 帧 〈《C) 和 响应 帧 (R) ， 通 过 5 个 M 位 来 表示 不 
同 功能 ， 上 有 具体 如 表 5-4 所 示 。 


表 5-4 无 编号 帧 的 类 型 及 编码 


A A bs be b 
SNRM 置 正常 响应 模式 i i Sb 
SARM/DM | 置 异 步 响应 模式 / 断 开 方式  & | ¥ | 11 | ava 
SABM | 时 异步 平衡 模式 | | 1 | 100 
SNRME 置 扩充 正常 响应 模式 | | | Wx a 
SARME | 置 扩充 异步 响应 模式 | | 1 | oo 
SABME ”| 时 扩充 异步 平 俐 模式 | | | i | 310 
DISC/RD ”| 断 链 / 请求 断 链 | ec | | oo | oi10 
SIM/RIM | 置 初始 化 方式 /请 求 初始 化 方式 | c | | 10 | 000 
UP 天 编号 查 光 _°¢ | | | 1o0 
Ul cc | | | 000 
xID mp | 101 
RESET | 复位 | ec | | :1 | oo 
FRMR Tea | 00 1 


5.7 面向 字符 的 PPP 同 步 传 输 协 议 


前 面 介绍 的 BSC、SDLC、HDLC 都 属于 局 域 网 中 的 数据 链 路 层 协 
议 ， 而 本 节 要 介绍 的 PPP (Point-to-Point Protocol， 点 对 点 协议 ) 是 一 
种 应 用 非常 广泛 的 广域网 数据 链 路 层 协议 。 如 我 们 在 使 用 Modem 进 行 
拨号 连接 时 就 需要 用 到 它 ， 路 由 器 设备 间 的 Serial 口 之 间 的 连接 也 要 圭 
装 这 个 协议 。 本 市 要 详细 介绍 这 一 协议 的 工作 原理 以 及 协议 结构 。 


5.7.1 PPP 简介 


在 点 对 点 链 路 上 ， 最 早 使 用 的 数据 链 路 层 协 议 不 是 PPP， 而 是 SLIP 
(Serial Line Internet Protocol， 串 行 线路 网 际 协议 ) ， 如 Windows 98 系 
统 中 Modem 拨 号 就 是 使 用 的 SLIP， 而 不 是 PPP。 但 SLIP 具 有 以 下 许多 
根本 无 法 适应 当时 网 络 技 术 发 展 和 应 用 需求 的 不 足 ， 具 体 如 下 : 


口 连接 速率 低 : SLIP 使 用 的 线路 速率 一 般 介 于 1200bps 和 19.2kbps 
之 间 ， 远 没有 PPP 的 连接 速率 高 (PPP 最 高 可 达 128kbps) 。 


口 不 能 自动 分 配 IP 地 址 ， 进 行 SLIP 连 接 的 通信 双方 必须 先 具备 静态 
IP 地 址 ， 不 能 在 连接 过 程 中 动态 分 配 卫 地 址 。 所 以 当时 的 SLIP 通 常 应 用 
于 专线 连接 中 ， 在 拨号 连接 中 也 仅 应 用 于 固定 IP 地 址 方式 的 连接 。 


口 无 协议 类 型 字段 : 在 SLIP 帧 中 没有 协议 类 型 字段 ， 只 文 持 默认 
的 IP 协 议 。SLIP 帧 很 简单 ， 只 是 在 人 P 包 的 最 前 面 和 最 后 面 各 加 一 个 
END 字 符 (0xc0) ， 作 为 帧 边界 ， 标 志 一 个 帧 的 起 始 和 结束 。 如 果 在 
包 中 有 END 字 符 ， 则 包 中 的 END 字 符 用 0xdb (ESC 字 符 ) 和 0xdc 两 个 
字符 来 替代 ;如 果 在 包 中 有 ESC 字 符 ， 则 ESC 字 符 用 0xdb (ESC 字 符 ) 
和 0xdd 两 个 字符 来 替代 ， 以 实现 数据 透明 传输 ， 如 图 5-21 所 示 。 


END ESC 


re ol 


!' |) 


END 用 以 下 两 个 字符 蔡 代 END 
SLIP 帧 


图 5-21 SLIP 帧 格式 及 透明 传输 示意 图 


口 无 帆 校 验 序列 (FCS) 字段 :， 从 图 5-21 中 可 以 看 出 ，SLIP 帧 中 没 
有 FCS 字 上 段 ， 因 此 在 SLIP 链 路 层 上 无 法 检测 出 传输 差错 ， 必 须 由 上 层 实 
体 或 具有 纠 错 能 力 的 Modem 来 解决 差错 问题 。 


PPP 协 议 是 在 SLIP 的 基础 上 发 展 起 来 的 点 对 点 数据 链 路 层 协 议 ， 对 
SLIP 以 上 问题 均 加 以 了 解决 ， 但 仍 是 面 癌 字符 的 链 路 层 协议 。 具 体 来 
讲 ，PPP 协 议 具 有 以 下 几 个 方面 的 特性 : 


口 PPP 在 连接 速率 上 可 以 远 高 于 SLIP， 可 以 最 高 达到 128kbps， 如 
像 v90 以 上 标准 的 Modem 都 可 达到 64kbps 。 


口 提供 了 协议 类 型 字段 和 帧 校 验 序列 (FCS) 字段 (如 图 5-22 所 
示 ) ， 使 得 PPP 除 了 支持 IP 协 议 包 封装 外 ， 还 可 以 封装 其 他 三 层 协议 
包 ， 如 当时 DECnet 和 Novell 的 Internet 网 包 交 换 (IPX) 。 另 外 有 了 FCS 
字段 ， 可 以 提供 各 种 差错 控制 功能 。 


8 8 8 16 可 变 16 ~ 32 8 位 


| 标志 ] 地 址 | 控制 ] 协议 | 信息 | FCS ] 标志 


图 5-22 PPP 帧 格式 


口 提 供 了 一 整套 方案 来 解决 链 路 建立 、 维 护 、 拆 除 、 上 层 协 议 协 
商 、 认 证 等 问题 。 这 些 功 能 是 通过 以 下 几 个 了 于 协议 来 完成 的 : 

. 链 路 控制 协议 (Link Control Protocol，LCP) : 用 于 建立 、 配 
置 、 测 试 和 管理 数据 链 路 连接 。 


:网 络 控制 协议 (Network Control Protocol，NCP) : 协商 该 链 路 上 
所 传输 的 数据 包 格 式 与 类 型 ， 建 立 、 配 置 不 同 的 网 络 层 协议 。 


:口令 认证 协议 (Password Authentication Protocol，PAP) 和 质询 握 
手 认 证 协议 (Challenge-Handshake Authentication Protocol，CHAP) : 
为 PPP 连 接 提供 用 户 认证 功能 ， 可 以 确保 PPP 连 接 的 安全 性 。 


家 庭 拨号 上 网 就 是 通过 PPP 在 用 户 端 和 运营 商 的 接 入 服务 器 之 间 建 
立 通 信 链 路 。 在 宽带 接 入 技术 日 新 月 异 的 今天 ，PPP 协 议 也 衍生 出 新 的 
应 用 。 典 型 的 应 用 是 在 ADSL (Asymmetrical Digital Subscriber Loop， 
非 对 称 数据 用 户 环 线 ) 接 入 方式 当中 ，PPP 协 议 与 其 他 的 协议 共同 派生 
了 符合 宽带 接 入 要 求 的 新 的 协议 ， 如 PPPoE (PPP over Ethernet) ， 
PPPoA (PPP over ATM) 。 


FE 


利用 以 太 网 (Ethernet) 资源 ， 在 以 太 网 上 运行 PPP 来 进行 用 户 认 
证 接 入 的 方式 称 为 PPPoE 。PPPoE 既 保护 了 用 户 方 的 以 太 网 资源 ， 又 完 
成 了 ADSL 的 接 入 要 求 ， 是 目前 ADSL 接 入 方式 中 应 用 最 广泛 的 技术 标 
准 。 同 样 ， 在 下 面 将 要 介绍 的 ATM (异步 传输 模式 ，Asynchronous 
Transfer Mode) 网 络 上 运行 PPP 协 议 来 管理 用 户 认证 的 方式 称 为 
PPPoA。 它 写 PPPoE 的 原理 相同 ， 作 用 相同 ; 不 同 的 是 它 在 ATM 网 络 上 
运行 ， 而 PPPoE 在 以 太 网 网 络 上 运行 ， 所 以 要 分 别 适应 ATM 标 准 和 以 
太 网 标准 。 


PPP 协 议 人 简单 和 功能 完整 的 特点 使 它 得 到 了 广泛 的 应 用 ， 相 信和 在 未 
来 的 网 络 技术 发 展 中 ， 还 可 以 发 挥 更 大 的 作用 。 


5.7.2 ”PPP 帧 结构 和 透明 传输 原理 


比较 图 5-22 所 示 的 PPP 帧 结构 和 图 5-17 所 示 的 HDLC 帧 结构 可 以 看 
出 ， 它 们 是 很 相似 的 ， 其 主要 区 别 是 PPP 帧 结构 中 多 了 一 个 协议 字段 
(用 来 所 封装 的 三 层 协 议 包 类 型 ) ， 而 且 PPP 是 面向 字符 的 协议 ， 而 
HDLC 是 面向 比特 的 协议 ， 所 以 自然 它们 所 采用 的 填充 方式 也 不 一 样 。 
下 面 完 介绍 PPP 帧 结构 中 各 字段 。 


1.PPP 帧 结构 


PPP 帧 结构 参见 图 5-22， 共 分 7 个 字段 ， 其 中 标志 字段 在 帧 的 最 前 
面 和 最 后 面 均 有 一 个 ， 其 他 字段 各 一 个 。 下 面 是 这 些 字段 的 具体 合 义 
说 明 。 


口 标 志 (Flag) : 用 来 标志 帧 的 起 始 或 结束 ， 占 8 位 (1 个 字 节 ) ， 
值 固定 为 01111110 (0x7E) ， 与 HDLC 帧 中 的 标志 字段 的 值 是 一 样 的 。 


口 地 址 (Address) : 本 来 是 用 来 标志 对 方 节点 地 址 的 ， 但 因 PPP 是 
点 对 点 通信 协议 ， 是 明确 知道 对 方 节 点 的 ， 在 实际 通信 中 是 无 须知 道 
对 方 的 数据 链 路 层 地 址 (也 就 是 MAC 地 址 ) ， 从 实际 通信 和 角度 考虑 ， 
此 地 址 字段 实际 上 是 没什么 意义 的 ， 所 以 在 PPP 帧 中 此 地 址 字段 为 固定 
的 11111111 (0xFF) 标准 广播 地 址 ， 占 8 位 (1 个 字 节 ) 。 这 与 HDLC 中 
的 地 址 字段 是 不 一 样 的 。 


口 控制 (Control) : 因为 PPP 本 身 是 一 种 可 靠 的 点 对 点 数据 路 层 通 
信 协 议 ， 无 须 像 HDLC 协 议 那样 需要 额外 提供 可 靠 的 链 路 连接 服务 ， 所 
以 PPP 只 有 一 种 帧 类 型 ， 那 就 是 UI (无 编号 信息 ) 帧 。 又 因为 它 是 无 编 
号 的 帧 ， 也 就 是 无 须 接收 端 对 收 到 的 帧 进行 确认 ， 所 以 ，PPP 帧 中 的 控 
制 字段 其 实 也 没有 意义 ， 值 固定 为 00000011 (0x03) 。 


口 协议 (Protocol) : PPP 帧 与 HDLC 帧 的 最 大 区 别 就 是 PPP 由 中 有 
协议 字段 ， 而 HDLC 帧 中 无 该 字段 。 之 所 以 PPP 帧 中 有 协议 字段 ， 是 因 
为 它 除 了 可 以 封装 IP 协 议 外 ， 还 可 封装 其 他 多 种 网 络 层 协 议 包 ， 如 
IPX、AppleTalk 等 。 协 议 字 段 占 16 位 〈2 个 字 节 ) ， 指 示 在 信息 字段 中 
封闭 的 数据 类 型 ， 如 0x0021 表 示 信 息 字 段 是 IP 数 据 包 ，0xC021 表 示 信 
筷 字 段 是 LCP ( 链 路 控制 协议 ) 数据 ，0x8021 表 示 信 息 字 段 是 NCP (网 
络 控制 协议 ) 数据 包 ，0xC023 表 示 信 息 字段 是 PAP 安 全 性 认证 数据 
包 ，0xC223 表 示 信 息 字 段 是 CHAP 安 全 性 认证 数据 包 ，0x0029 表 示 信 息 
字段 为 Apple Talk 协 议 数据 包 ，.……. 


口 信息 (Information) : 来 自 上 层 (“网 络 层 ”) 的 有 效 数据 ， 可 以 
是 任意 长 度 ， 默 认为 1500 字 方 ， 如 果 不 够 该 长 度 ， 还 可 以 通过 填充 方 


法 达到 这 个 长 度 。 


口 帧 校 验 序列 (FCS) : 使 用 16 位 的 循环 见 余 校 验 计算 信息 字段 中 
的 校 验 和 ， 以 认证 数据 的 正确 性 。 


2. 透 明 传输 


从 前 面 介绍 的 PPP 帧 结构 中 可 以 看 出 ， 在 帧 的 首尾 均 有 一 个 用 于 标 

志 帧 边界 的 标志 字段 ， 其 值 均 固 定 为 01111110 (0x7E) ， 这 就 同样 要 
面 对 一 个 问题 ， 那 就 是 当 在 信息 字段 中 出 现 和 标志 字段 一 样 的 比特 
0x7E 时 ， 接 收 端 可 能 误 把 这 些 位 当成 帧 边界 。 为 了 解决 这 个 问题 ， 也 
就 是 实现 透明 的 数据 传输 ， 就 必须 采取 一 些 措 施 。 但 因为 PPP 是 面向 字 
符 协 议 ， 所 以 它 不 能 采用 HDLC 所 使 用 的 零 比 特 插 入 法 ， 而 是 使 用 一 种 
特殊 的 字符 〈 也 天 是 前 面 所 说 的 转 义 字符 ) 0x7D 进 行 填充 。 具 体 
的 做 法 是 将 信息 字段 中 出 现 的 每 一 个 0x7E 字 节 转 变 成 2? 字 人 序列 

(0x7D，0x5E) ， 即 01111101 01011110; 如 果 信 息 字段 中 出 现 一 个 
0x7D 的 字 记 ， 则 要 将 其 转变 成 2 字 市 序列 (0x7D，0x5D) 即 01111101 
01011101; 如 果 信 息 字段 中 出 现 ASCII 码 的 控制 字符 (如 值 为 0x27 的 
ESC 字 符 ) ， 则 在 该 字符 前 面 要 加 入 一 个 0x7D 字 节 ， 如 图 5-23 所 示 。 
这 样 做 的 目的 是 防止 这 些 表面 上 的 ASCII 码 控制 字符 被 错误 地 解释 为 控 


制 字 符 。 


IP 包 


用 以 下 两 个 序 节 替代 


图 5-23 PPP 帧 格式 及 透明 传输 示意 图 


PPP 帧 


5.7.3 ”PPP 链 路 建立 、 使 用 和 拆除 流程 


在 PPP 通 信 中 ， 因 为 不 是 像 局 域 网 中 的 链 路 那样 始终 连接 的 ， 所 以 
在 建立 PPP 通 信 前 ， 通 信 双 方 必 须 协 商 建立 链 路 连接 ， 在 链 路 建立 后 才 
可 进行 数据 传输 ， 数 据 传输 完成 后 又 可 拆除 原来 建立 的 链 路 。 整 个 过 
程 分 为 五 个 阶段 ， 即 Dead (死亡 ) 阶段 、Establish 〈 链 路 建立 ) 阶段 、 
Authenticate (身份 认证 ) 阶段 、Network (网 络 控制 协商 ) 阶段 和 
Terminate (结束 ) 阶段 。 不 同 阶段 进行 不 同 协议 的 协商 ， 只 有 前 面 的 
协议 协商 出 结果 后 ， 才 能 转 入 下 一 个 阶段 协议 的 协商 ， 如 图 5-24 所 示 。 


成 功 
Establish Authenticate 


Terminate Network 


图 。 5-24 PPP 链 路 建立 、 使 用 和 拆除 流程 


PPP 链 路 建立 、 使 用 和 拆除 的 具体 流程 如 下 : 


1) 当 有 用 户 向 ISP 或 者 对 端 节 点 发 起 PPP 连 接 请 求 时 ， 首 先 打开 物 
理 接口 ， 然 后 PPP 在 建立 链 路 之 前 移 通过 封装 了 LCP 的 PPP 帧 与 接口 进 
行 协商 ， 协 商 内 容 包括 工作 方式 是 SP 〈 单 PPP 通 信 ) 还 是 MP (多 PPP 
通信 ) 、 认 证 方式 和 最 大 传输 单元 等 。 


2) LCP 协 商 完 成 后 就 进入 Establish 阶段 ， 进 行 数据 链 路 的 建立 。 
这 时 主要 是 启用 PPP 数 据 链 路 层 协议 ， 对 接口 进行 封装 。 如 果 启 用 成 
功 ， 则 进入 下 一 身份 认证 (Authenticate) 阶段 ， 并 保持 LCP 为 激活 状 
态 ， 否 则 返回 关闭 接口 ，LCP 的 状态 为 关闭 。 


3) 如 果 数 据 链 路 建立 成 功 ， 则 进入 到 Authenticate 阶 段 ， 对 请 求 连 
接 的 用 户 进行 号 份 认证 。 有 具体 要 根据 通信 双方 所 配置 的 号 份 认证 方式 
来 确定 是 采用 CHAP 还 是 PAP 身 份 认证 。 


4) 如 果 认证 成 功 就 进入 Network 阶 段 ， 使 用 封装 了 NCP 的 PPP 帧 与 
对 应 的 网 络 层 协议 进行 协商 ， 并 为 用 户 分 配 一 个 临时 的 网 络 层 地 址 
(如 IP 地 址 ) ; 如 果 身 份 认证 失败 ， 则 直接 进入 Terminate (结束 ) 阶 
段 ， 拆 除 链 路 ， 返 回 到 Dead 阶 段 ，LCP 状 态 转 为 Down。 


5) PPP 链 路 将 一 直 保 持 通信 ， 直 至 有 明确 的 LCP 或 NCP 帧 关闭 这 
条 链 路 ， 或 发 生 了 某 些 外 部 事件 (如 用 户 的 干预 ， 进 入 到 Terminate 
阶段 ， 然 后 关闭 NCP 协 议 ， 释 放 原 来 为 用 户 分 配 的 临时 网 络 层 地 址 ， 
最 后 返回 到 Dead 阶 段 ， 关 闭 LCP 。 


5.7.4 PPP 的 PAP/CHAP 身 份 认证 


在 PPP 通 信 中 ， 可 以 采用 PAP (密码 认证 协议 ) 或 者 CHAP (质询 
握手 认证 协议 ) 身份 认证 方式 对 连接 用 户 进行 身份 认证 ， 以 防 非 法 用 
户 的 PPP 连 接 。 如 果 双 方 达成 一 致 ， 也 可 以 不 采用 任何 身份 认证 方式 

(如 一 般 情况 下 的 路 由 器 间 Serial 口 之 间 的 PPP 连 接 ) 。 


1.PAP 冉 份 认证 


PAP 身 份 认 证 过 程 非常 简 单 ， 是 一 个 二 次 握手 机 制 ， 整 个 认证 过 程 
仅 需 两 个 步 又: 被 认证 方 发 送 认证 请 求 ~ 认证 方 给 出 认证 结果 。 


PAP 身 份 认 证 可 以 在 一 方 进行 ， 即 由 一 方 认证 为 一 方 喘 份 ， 也 可 以 
进行 双向 身份 认证 ， 也 就 是 既 要 PAP 服 务 器 对 PAP 客 户 端的 合法 性 进行 
认证 ，PAP 客 户 端 也 需要 对 PAP 服 务 器 进行 认证 ， 以 确保 用 于 认证 的 
PAP 服 务 囊 是 合法 的 。 如 果 十 双 辐 认证 ， 则 要 求 认 证 的 双方 都 要 通过 对 
方 的 认证 程序 ， 否 则 无 法 在 双方 之 间 建 立 通 信和 链 路 。 


下 面 以 单 向 认证 为 例 介绍 PAP 认 证 过 程 ， 如 图 5-25 所 示 。 但 要 注意 
的 是 ，PAP 认 证 是 由 被 认证 方 (也 就 是 PAP 客 户 端 ) 首先 发 起 的 。 


发 送 PAP 认证 请 求 


Cs 


认证 成 功 


一 


或 认证 失败 


图 。 5-25 PAP 身份 认证 的 两 次 握手 


1) 发 起 PPP 连 接 的 客户 端 (被 认证 方 ) 首先 向 担当 身份 认证 的 
PAP 服 务 器 端 (如 是 向 ISP 挨 号 ， 则 PAP 服 务 器 在 ISP 端 ， 如 果 是 路 由 器 
的 串口 对 连 ， 则 PAP 服 务 器 必须 要 在 对 端 设备 上 配置 ) 发 送 一 个 认证 请 
求 帧 ， 其 中 就 包括 用 于 身份 认证 的 用 户 名 和 密码 。 


2) PAP 服 务 器 端 (认证 方 ) 在 收 到 客户 端 发 来 的 认证 请 求 帧 后 ， 
先 查 看 服务 器 本 地 配置 的 用 户 账户 数据 库 ， 看 是 否 有 客户 端 提供 的 用 
户 名 /密码 对 信息 (这 个 用 户 账户 数据 库存 必须 先 在 PAP 服 务 器 端 配 置 
好 ) 。 如 果 有 ， 则 表明 客户 端 具 有 合法 的 用 户 账户 信息 ， 向 PAP 客 户 端 
返回 一 个 认证 确认 (ACK) 帧 ， 表 示 认 证 成 功 ， 该 用 户 可 以 与 PAP 服 务 
器 端 建立 PPP 连 接 ; 否则 返回 一 个 认证 否认 (NAK) 帧 ， 表 示 认 证 失 
败 ， 当 然 客户 端 也 就 不 能 与 PAP 服 务 器 端 建立 PPP 连 接 了 “。 但 这 里 要 注 
意 的 是 ， 如 果 第 一 次 认证 失败 ， 并 不 会 马上 直接 将 链 路 关闭 ， 而 是 会 
在 PAP 客 户 端 提 示 可 以 党 试 以 新 的 用 户 账户 信息 进行 再 次 认证 ， 只 有 当 


认证 不 通过 次 数 达 到 一 定 值 (默认 为 4) 时 才 会 关闭 链 路 ， 以 防止 因 误 
传 、 网 络 干扰 等 造成 不 必要 的 LCP 重 新 协商 过 程 。 


PAP 身 份 认证 的 特点 是 ， 用 于 身份 认证 的 用 户 名 及 密码 在 网 络 上 是 
以 明文 〈 也 就 是 不 加 密 ) 方式 进行 传输 的 ， 如 在 传输 过 程 中 被 截获 ， 
便 有 可 能 对 网 络 安全 造成 极 大 的 威胁 ， 所 以 PAP 并 不 是 一 种 安全 有 效 的 
认证 方法 。 


以 上 介绍 的 是 PAP 单 向 认证 过 程 ， 仪 两 步 (一 问 一 管 的 形式 ) ， 很 
简单 。PAP 双 向 认证 过 程 与 单 向 认证 过 程 类 似 ， 只 不 过 此 时 PPP 链 路 的 
两 背 同 时 具有 客户 站 和 服务 万 双重 角色 ， 任 何 一 问 都 可 癌 对 方 发 送 认 
证 请 求 ， 同 时 对 对 方 发 来 的 认证 请 求 进行 认证 。 


2.CHAP 身 份 认 证 


CHAP 认 证 过 程 相对 前 面 介 绍 的 PAP 认 证 来 说 更 为 复杂 ， 它 采用 的 
是 三 次 握手 机 制 (而 不 是 PAP 中 的 两 次 握手 机 制 ) ， 整 个 认证 过 程 要 经 
过 三 个 主要 步骤 : 认证 方 要 求 被 认证 方 提 供认 证 信息 -被 认证 方 提供 
认证 信息 一 认证 方 给 出 认证 结果 。 


另外 ，CHAP 身 份 认证 方式 相对 PAP 认 证 方式 来 说 更 加 安全 ， 因 为 
在 认证 过 程 中 ， 用 于 认证 的 用 户 名 和 密码 不 是 直接 以 明文 方式 在 网 络 
上 传输 的 ， 而 是 经 过 MD5 之 类 的 摘要 加 密 协 议 随机 产生 的 密 钥 ， 而 且 
这 个 密 钥 是 有 时 效 的 ， 原 密 钥 失 效 后 会 随机 产生 新 的 密 钥 ， 所 以 即使 


在 通信 过 程 中 密 钥 被 非法 用 户 破 解 了 ， 也 不 会 适用 于 后 面 的 通信 截 
取 。 


与 同 PAP 认 证 一 样 ，CHAP 认 证 也 可 以 是 单 向 或 者 双向 的 。 如 果 是 
双向 认证 ， 则 要 求 通信 双方 均 要 通过 对 对 方 请 求 的 认证 ， 否 则 无 法 在 
双方 建 并 PPP 链 路 。 在 此 ， 我 们 仍 以 单 向 认证 为 例 介绍 CHAP 认 证 流 
程 ， 具体 如 图 5-26 所 示 。 注 意 ，CHAP 身 份 认证 首先 是 由 CHAP 服 务 器 
端 发 起 的 。 


认证 质询 
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认证 响应 
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图 5-26 CHAP 身 份 认 证 的 三 次 握手 


1) 当 PPP 链 路 建立 起 来 后 ， 采 用 CPAP 吴 份 认证 方式 时 ， 首 先是 由 
CHAP 服 务 器 (认证 方 ) 不 断 地 以 产生 一 个 随机 序列 号 的 质询 
challenge， 又 称 挑 战 ) 字符 串 帧 发 送 给 CHAP 客 户 端 〈 被 认证 方 ) ， 
询问 客户 端 (被 认证 方 ) 是 否 要 进行 身份 认证 。 直 到 该 客户 端 为 这 个 
质询 做 出 了 啊 应 ， 也 惑 是 进入 了 下 面 的 第 2 步 。 


2) 客户 端 在 收 到 服务 器 端 发 来 的 质询 消息 后 ， 把 自己 要 用 于 身份 
认证 的 用 户 名 和 密码 (这 需要 事先 在 客户 端 设备 中 配置 好 ) 通过 MD5 
摘要 加 密 协议 生成 一 个 随机 序列 的 响应 帧 发 送 给 服务 器 端 。 


3) 服务 器 端 在 收 到 来 自 客户 端的 响应 后 ， 同 样 利 用 MD5 加 密 协 议 
解密 出 其 中 的 认证 用 户 名 和 密码 ， 然 后 在 服务 套 本 地 用 户 账户 数据 库 
(也 是 需要 事先 在 服务 器 端 配置 好 的 ) 中 查找 ， 看 是 否 有 相同 的 账户 
言 奶 。 如 果 找 到 一 样 的 账户 信息 ， 表 明 请 求 认 证 的 客户 疾 是 合法 的 ， 
通过 认证 ， 人 允许 客户 端 发 起 的 PPP 连 接 ， 人 否则 拒绝 认证 ， 表 示 认 证 失 
败 。 与 PAP 一 样 ， 第 一 次 认证 失败 后 ， 也 不 会 马上 关闭 链 路 ， 而 是 再 次 
向 客户 端 提示 输入 新 的 用 户 名 和 密码 进行 再 次 认证 ， 直 到 规定 的 最 高 


尝试 次 数 。 


CHAP 认 证 方式 的 最 关键 一 点 就 是 采用 了 MD5 搞 要 加 密 协 议 ， 用 于 
认证 的 用 户 名 和 密码 是 直接 在 摘要 消息 中 经 过 加 密 的 ， 所 以 不 会 在 网 
络 中 以 明文 方式 传输 ， 因 此 它 的 安全 性 要 比 PAP 高 。 


5.8 ”数据 链 路 层 主要 网 络 设备 


介绍 完 数 据 链 路 层 主要 功能 、 服 务 后 ， 下 面 我 们 再 来 简单 介绍 工 
作 在 数据 链 路 技 上 的 主要 网 络 设备 。 在 常见 的 网 络 设备 中 ， 如 网 卡 、 
网 桥 和 二 层 交 换 机 。 


5.8.1 计算 机 网 卡 


说 到 计算 机 网 卡 (也 叫 网 络 适配器 ) ， 大 家 可 能 认为 这 没什么 好 
说 的 ， 大 家 都 见 过 、 用 过 。 网 卡 是 安装 在 计算 机 上 ， 用 来 连接 计算 机 
网 络 的 ， 是 计算 机 网 络 中 最 基础 的 网 络 设备 。 目 前 在 计算 机 局 域 网 
中 ， 网 卡 类 型 总 的 来 说 主要 可 分 为 有 线 以 太 网 卡 、WLAN 无 线 网 卡 两 
大 类 。 下 面 分 别 予 以 介绍 。 


1. 有 线 以 太 网 卡 


在 企业 局 域 网 中 ， 我 们 通常 所 说 的 有 线 网 卡通 常 就 是 指 以 太 网 
卡 ， 所 以 在 此 也 仅 限 于 对 以 太 了 网卡 的 介绍 ， 而 不 再 涉及 目前 在 企业 局 
域 网 中 很 少见 到 的 其 他 网 络 类 型 的 网 卡 ， 如 令 牌 环 网 卡 、 令 牌 总 线 网 
卡 和 FDDI 网 卡 等 。 男 外 ， 网 卡 除了 要 区 分 网 络 类 型 外 ， 还 可 根据 所 应 
用 的 环境 分 为 普通 工作 站 网 卡 和 服务 器 网 卡 两 类 。 


有 线 网 卡 还 可 根据 以 下 几 个 方面 可 以 进行 进一步 划分 : 一 是 网 卡 
的 主机 接口 ， 也 就 是 网 卡 与 计算 机 的 接口 ， 二 是 网 卡 主机 接口 总 线 的 
位 数 ; 三 征 网 卡 的 网 络 接口 类 型 ， 也 对 应 了 网 卡 所 文 持 的 传输 介质 类 
型 ;四 是 网 卡 所 文 持 的 以 太 网 标准 。 


在 主机 接口 方面 ， 有 线 网 卡 主要 有 以 下 几 种 类 型 : 一 是 最 常见 的 
PCI 总 线 接口 ， 二 是 微型 PCI (PCMCIA) 接口 ， 三 是 在 服务 器 网 卡 用 
得 比较 多 的 PCI-X 和 PCI-E 接 口 。 这 几 种 主机 接口 类 型 网 卡 如 图 5-27 所 


修 ° 


PCMCIA 接口 


PCI 接口 _ 
PCI-X 接口 PCI-E 接口 


图 5-27 PCI、PCMCIA、PCI-X 和 PCI-E 接 口 网 卡 


在 有 线 网 卡 的 网 络 接口 方面 ， 主 要 对 应 的 是 不 同 的 传输 介质 。 
为 使 用 同 轴 电 线 的 以 太 网 目前 在 企业 局 域 网 中 比较 少见 了 ， 所 以 在 此 
不 再 介绍 粗 / 细 同 轴 电 线 接口 的 以 太 网 卡 ， 仅 介绍 双 绞 线 接口 以 太 网 卡 
和 光纤 接口 以 太 网 卡 。 


双 绞 线 接口 以 太 网 卡 使 用 最 普遍 ， 对 应 双 绞 网 线 连接 器 的 接口 为 
RJ-45 类 型 。RJ-45 连 接 器 (俗称 水 晶 头 ) 和 网 卡 上 对 应 的 RJ-45 网 络 接 


口 如 图 5-28 所 示 。 
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图 5-28 RJ-45 连 接 器 和 网 络 接口 


使 用 光纤 作为 传输 介质 的 网 卡 所 对 应 的 光纤 连接 器 接口 有 好 几 
种 ， 最 常见 的 有 ST、SC、FC、LC 四 种 。 这 在 本 书 第 4 章 中 有 详细 介 
绍 ， 在 此 不 再 长 述 。ST、SC、FC 和 LC 这 四 种 主要 的 光纤 连接 器 接口 
如 图 5-29 所 示 。 图 5-30 所 示 是 目前 应 用 最 广 的 两 种 光纤 网 络 接口 SC 和 
LC 的 网 卡 示 例 。 


图 5-29 ST、SC、FC 和 LC 光纤 连接 器 接口 
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图 5-30 SC 和 LC 网 络 接口 网 卡 示例 


有 线 网 卡 除了 可 以 按 主机 接口 和 网 络 接口 划分 外 ， 还 可 以 根据 网 
卡 所 文 持 的 网 络 标准 来 划分 。 目 前 ， 在 有 线 以 太 网 工作 站 中 我 们 通常 
采用 支持 10/100Mbps 自 适应 的 双 绞 线 快 速 以 太 网 卡 ， 性 能 要 求 高 一 些 
的 可 能 会 用 到 支持 自 适应 的 10/100/1000Mbps 双 绞 线 千 兆 以 太 网 卡 。 而 
服务 右上 的 网 卡 目 前 基本 上 都 是 目 适 应 的 10/100/1000Mbps 双 弘 线 千 兆 
以 太 网卡 ， 或 者 纯 1000Mbps 的 光纤 千 兆 以 太 网 卡 。 


另外 ， 支 持 的 这 些 不 同 网 络 标 准 的 PCI 接 口 以 太 网 卡 ， 所 对 应 的 主 
机 接口 工作 模式 也 会 有 所 不 同 。 工 作 站 上 普遍 使 用 的 PCI 接 口 快速 以 太 
网 卡 基 本 上 都 是 32 位 的 ， 而 千 兆 以 太 网 卡 基 本 上 都 是 64 位 的 。 要 注意 
的 是 ， 纯 64 位 的 干粮 以 太 网 卡 与 同 后 兼容 32 位 的 64 位 以 太 网 卡 的 PCI 总 
线 接口 金 手指 结构 〈( 金 手指 长 度 和 缺口 数 不 一 样 ) 是 不 一 样 的 。 如 图 5- 
31a 所 示 是 32 位 的 PCI 搂 口 快 速 以 太 了 网卡， 图 5-31b 所 示 为 纯 64 位 的 PCI 


接口 千 兆 以 太 网 卡 ， 图 5-31c 为 同时 支持 32 位 和 64 位 的 PCI 接 口 千 兆 以 大 
网 卡 。 


1 个 缺口 | 2 个 缺口 3 个 缺口 
a) 32 位 b) 纯 64 位 c) 32 位 和 64 位 


图 5-31 三 种 不 同 工 作 模式 的 以 太 网 卡 
2.WLAN 网 卡 


在 WLAN 网 卡 方面 ， 相 对 有 线 网 卡 来 说 要 简单 一 些 ， 那 是 因为 就 
目前 来 说 WLAN 技 术 还 不 如 有 线 网 络 那 么 先进 ， 所 以 在 主机 接口 方面 
没有 什么 特殊 要 求 ， 一 般 的 32 位 PCI 或 者 USB 1.1、2.0 或 者 3.0 版 本 接口 
即 可 满足 。 


在 WLAN 网 卡 选 择 方 面 主要 考虑 网 卡 的 主机 接口 和 所 使 用 的 
WLAN 技 术 标 准 。 在 台式 机 工作 站 中 通常 选用 PCI 或 者 USB 接 口 的 
WLAN 网 卡 (主要 是 PCI 接 口 ) ， 如 图 5-32 所 示 。 


a) PCI b) USB 


图 5-32 PCI 和 和 USB 接口 的 WLAN 网 卡 


对 于 笔记 本 电脑 用 户 则 可 以 选择 PCIMCIA 和 USB 两 种 接口 类 型 的 
无 线 局 域 网 网 卡 。 而 PCMCIA 接 口 又 分 16 位 的 PCMCIA 和 32 位 的 
CardBus 两 种 接口 类 型 ， 如 图 5-33 所 示 。 在 无 线 局 域 网 标准 上 ， 目 前 至 
少 建 议 应 选择 具有 54Mbps 速 率 的 IEEE 802.11g 标 准 无 线 网 卡 产 品 ， 普 
遍 采 用 的 是 支持 600Mbps 速 率 的 IEEE 802.11n 标 准 的 无 线 网 卡 。 有 关 


WLAN 标 准 的 内 容 将 在 下 章 介绍 。 


a) PCMCIA b) CardBus 


图 5-33 PCMCIA 和 CardBus 接 口 WLAN 网 卡 


5.8.2 ”网 桥 及 其 工作 原理 


网 桥 (Bridge) 是 早期 的 两 端口 二 层 网 络 设备 ， 用 来 连接 不 同 网 段 
的 计算 机 网 络 设备 (如 图 5-34 所 示 ) ， 同 时 它 又 可 隔离 冲突 域 ， 因 为 它 
的 两 个 端口 不 是 共享 一 条 背 板 总 线 (分 别 有 一 条 独立 的 交换 信道 ) ， 
比 当时 的 集线器 (Hub) 性 能 更 好 (集线器 上 各 端口 都 是 共享 同一 条 背 
板 总 线 的 ) 。 后 来 ， 网 桥 被 具有 更 多 端口 、 同 时 也 可 隔离 冲突 域 的 交 
换 机 (Switch) 所 取代 。 


这 两 个 网 段 是 处 
于 同一 网 络 中 的 


图 5-34 网 桥 连接 的 两 个 物理 网 段 


1. 理 解 “ 网 桥 ?" 的 侣 义 


也 有 人 把 “网 桥 * 比 喻 成 一 个 聪明 的 中 继 嚣 (Repeater) 。 因 为 中 继 
如 只 是 对 所 接收 的 信号 进行 放大 ， 然 后 直接 发 送 到 男 一 个 问 口 连接 的 
电 统 上 ， 主 要 用 于 扩展 网 络 的 物理 连接 范围 ， 而 网 桥 除 了 可 以 扩展 网 
络 的 物理 连接 范围 外 ， 还 可 以 对 MAC 地 址 进行 分 区 ， 隔 离 不 同 物理 网 
段 之 间 的 碰撞 (也 就 是 隔离 “冲突 域 ?) 。 集 线 器 和 中 继 器 都 是 物理 层 
设备 ， 而 网 桥 属于 二 层 设备 。 


我 们 经 闻 听 到 这 样 的 六法 ， 那 束 是 “网 桥 ? 和 是 一 种 可 连接 不 同 网 段 
的 二 层 网 络 设备 〈 二 层 交 换 机 也 一 样 ) ， 一 个 端口 可 以 连接 一 个 网 
段 。 所 以 很 多 人 不 总 在 纳 同 ， 网 桥 怎 么 能 连接 不 同 网 段 呢 ?其 实 这 是 
因为 大 家 对 这 里 所 说 的 “网 段 * 并 不 理解 。 其 实 这 里 “网 段 * 更 准确 地 讲 应 
该 是 叫 “ 物 理 网 段 *， 是 指 IP 地 址 属于 同一 网 络 地 址 段 《也 就 是 耳 地 址 中 
的 网 络 ID 一 样 ) ， 位 于 不 同 地 理 位 置 的 不 同 LAN 分 段 ， 是 基于 物理 意 
义 上 的 地 理 区 域 进行 划分 的 。 我 们 利 说 的 网 段 是 指 IP 地 址 属于 不 同 网 
络 地 址 段 的 网 络 或 子 网 ， 是 一 个 三 层 概 念 ， 其 实 这 应 该 叫做 逻辑 网 
段 ， 是 基于 逻辑 意义 上 的 网 络 地 址 进行 划分 的 。 


无 论 是 网 桥 ， 还 是 二 层 交 换 机 ， 虽 然 每 个 端口 可 以 连接 一 个 网 
段 ， 但 是 它们 所 连接 的 主机 都 在 同一 网 络 ， 或 者 同一 子 网 中 。 如 连接 
的 主机 位 于 不 同 办 公 室 或 者 不 同 办 公 楼 中 ， 则 可 采用 同一 网 络 地 址 的 
两 个 或 多 个 小 LAN， 以 组 成 一 个 可 以 统一 管理 的 大 LAN。 但 要 注意 的 
征 ， 因 为 网 桥 只 有 两 个 端口 ， 所 以 所 连接 的 两 个 物理 网 段 的 主机 通 秆 


就 是 由 当时 的 集线器 进行 集中 连接 的 (网 桥 端 口 通常 不 是 直接 连接 主 
机 的 ) 。 软 件 中 通常 所 说 的 桥接 (如 VMware 中 的 桥接 工作 模式 ) 也 就 
征 网 桥 的 作用 ， 它 连接 的 也 是 同一 网 络 或 子 网 中 的 两 个 网 段 。 


2. 网 桥 工作 原理 解析 


前 面 说 到 了 网 桥 具 有 两 种 主要 特性 : 一 是 可 基于 物理 网 段 的 MAC 
地 址 进行 学 习 ， 二 是 可 以 隔离 冲突 域 。 下 面 通过 一 个 示例 来 进行 解 
析 。 


假设 图 5-34 中 所 示 的 物理 网 段 1 和 物理 网 段 2 中 的 主机 痢 是 通过 集 线 
器 集中 连接 的 ， 则 这 样 这 两 个 物理 网 段 各 自 形 成 一 个 冲突 域 ， 因 为 集 
线 器 是 采用 共享 介质 传输 的 ， 而 网 桥 的 背 板 信道 不 是 共 译 的 (每 个 端 
口 的 数据 收发 都 有 一 条 单独 的 信道 ) ， 所 以 一 个 集线器 就 是 一 个 冲突 
域 。 网 桥 的 数据 转发 原理 如 图 5-35 所 示 。 下 面 是 具体 的 解析 。 


中 有 无 对 应 的 记录 该 源 MAC 地 
MAC 地 址 ? 址 所 在 物理 网 段 


源 MAC 地 址 与 目的 
MAC 地 址 是 否 在 同 
一 物理 网 段 


转发 到 另 一 端口 所 连 
网 段 ， 然 后 再 由 该 网 
段 的 集线器 进行 广播 


不 转发 ， 在 源 目的 主机 收 到 数据 帧 ， 
网 桥 记 录 目 的 MAC 地 


MAC 地 址 所 在 物 
理 网 段 进行 揪 址 所 对 应 的 物理 网 自 


结束 


图 5-35 网 桥 数据 转发 原理 示意 图 


说 明 MAC 地 址 表 也 就 是 通常 所 说 的 CAM (Content Addressable 
Memory， 内 容 可 寻 址 存储 器 ) 表 ， 保 存 的 是 对 应 MAC 地 址 主机 与 所 连 
接 的 交换 机 端口 的 上 映射。 这 个 映 映 表 项 可 以 由 管理 员 手 动 绑 定 创建 ， 

也 可 以 由 交换 机 自动 学 习 得 到 。 在 交换 机 上 可 以 通过 一 些 命令 (如 
Cisco 交 换 机 是 使 用 show mac-address-table 命 令 ) 查看 。 下 面 是 一 个 在 
交换 机 上 查看 MAC 地 址 和 问 口 映射 表 的 示例 ， 其 中 列 出 了 交换 机 中 为 
CPU 分 配 的 静态 (static) MAC 地 址 和 通过 学 习 功 能 自动 学 习 得 到 的 动 
态 dynamic) MAC 地址， 其 中 的 Ports 列 显示 的 是 对 应 MAC 地 址 主机 
所 连接 的 端口 ，VLAN 列 则 为 对 应 主机 连接 端口 所 属 的 VLAN 。 


switch#show mac-address-table 
Mac Address Table 


Vlan Mac Address Type Ports 

All ULOUUcoS eee STATIC CPU 

All 0100.066e6.cecd STATIC CPU 

All Fer feefea referf STATIC CPU 
0000 .0c07 .accb DYNAMIC Gi0/1 


1 0002.8501 .de00 DYNAMIC Gi0/1 


1 0015.£f915.8e80 DYNAMIC Gi0/1 

1 0016.7694.c009 DYNAMIC Gi0/1 

1 0020.ed14 .399c DYNAMIC Gi0/1 

1 0030.b637.8e10 DYNAMIC Gi0/1 

a 0050 .bal0.404a DYNAMIC Gi0/1 
100 0007.847b.c40a DYNAMIC Gi0/1 
100 00d0.d3a4.7cec DYNAMIC Gi0/1 
L110 0006 .28bb.71c0 DYNAMIC Gi0/1 
110 00d0.d3a4.7cec DYNAMIC Gi0/1 
120 0000.b497.8250 DYNAMIC Fa0/20 
120 0002.b3d8.68e7 DYNAMIC Fa0/20 
120 0002 .b3d8 .6928 DYNAMIC Fa0/20 
120 0003 .a03a.03fc DYNAMIC Fa0/19 


现 假设 图 5-34 所 示 网 络 中 的 一 台 PC 要 向 另 一 台 PC 发 送 数据 。 因 为 
集 线 帮 也 是 物理 层 设备 ， 不 能 识别 帧 中 的 MAC 地 址 ， 所 以 无 论 是 哪 台 
主机 要 发 送 数据 ， 在 集线器 上 都 是 以 广播 方式 进行 的 ， 连 接 该 集线器 
上 的 所 有 区 点 都 会 收 到 这 个 广播 帧 ， 包 括 网 桥 连接 到 该 集线器 的 端 
i 


1) 当 网 桥 收 到 集线器 的 广播 帧 后 ， 网 桥 会 把 帧 中 的 源 MAC 地 址 和 
目的 MAC 地 址 与 网 桥 缓存 中 保存 的 MAC 地 址 表 进 行 比较 。 


2) 最 初 ， 网 桥 的 缓存 中 是 没有 任何 MAC 地 址 的 ， 所 以 一 开始 它 也 
不 知道 哪 台 主机 在 哪个 物理 网 段 上 ， 收 到 的 所 有 帧 都 直接 以 泛 洪 方 式 
(也 是 复制 原 数据 帧 ) 转发 到 另 一 个 端口 上 ， 同 时 会 把 数据 帧 中 的 源 
MAC 地 址 所 对 应 的 物理 网 段 记 录 下 来 (其实 就 是 与 对 应 的 网 桥 端 口 对 
应 起 来 ) 。 


3) 在 数据 帧 被 某 个 PC 机 接收 后 ， 也 会 把 对 应 目的 MAC 地 址 所 对 
应 的 物理 网 段 记录 在 缓存 中 的 MAC 表 中 。 这 样 ， 经 过 多 次 这 样 的 记 
杂 ， 束 可 以 在 MAC 地 址 表 中 把 整个 网 络 中 各 主机 MAC 地 址 与 对 应 的 物 
理 网 段 全 部 记录 下 来 。 因 为 网 桥 的 端口 通常 是 连接 集线器 的 ， 所 以 一 
个 网 桥 端 口 会 与 多 个 主机 MAC 地 址 进行 映射 。 


4) 当 网 桥 收 到 的 数据 帧 中 源 MAC 地 址 和 目的 MAC 地 址 都 在 网 桥 
MAC 地 址 表 中 可 以 找到 时 ， 网 桥 会 比较 这 两 个 MAC 地 址 是 否 属于 同一 
个 物理 网 段 。 如 果 是 同一 物理 网 段 ， 则 网 桥 不 会 把 该 帧 转发 到 下 一 个 
端口 ， 直 接 丢 弃 ， 起 到 冲突 域 隔离 作用 。 相 反 ， 如 果 两 个 MAC 地 址 不 
在 同一 物理 网 段 ， 则 网 桥 会 把 从 一 个 物理 网 段 发 来 的 帧 转发 到 连接 另 
一 个 物理 网 段 上 ， 然 后 再 通过 所 连接 的 集线器 进行 复制 方式 的 广播 。 


5.8.3 ”二 层 交 换 机 概述 


在 计算 机 网 络 设备 还 有 一 种 是 工作 在 数据 链 路 层 的 ， 那 束 是 二 层 
交换 机 (其 实 三 层 或 以 上 层次 交换 机 同样 提供 二 层 交 换 功 能 ，。 


交换 机 (Switch) 可 以 说 同时 是 集线器 和 网 桥 的 升级 换代 产品 ， 
为 交换 机 具有 集线器 一 样 的 集中 连接 功能 ， 同 时 它 又 具有 网 桥 的 数据 
交换 功能 。 所 以 可 以 这 样 说 ， 交 换 机 是 带 有 交换 功能 的 集线器 ， 或 者 
交换 机 是 多 端口 的 网 桥 。 外 形 上 ， 集 线 器 与 交换 机 产品 没什么 太 大 
别 ， 如 图 5-36a 所 示 为 一 球 集 线 侣 产品 ， 而 图 5-36b 所 示 为 一 款 交 换 机 


产品 
HH ” 


Sy 


j 


kk 区 


a) 集线器 b) 交换 机 


图 5-36 和 集 线 占 与 交换 机 的 外 观 比较 


从 图 中 的 对 比 可 以 看 出 ， 交 换 机 与 集 线 带 一 样 ， 是 一 个 具有 许多 
同类 端口 的 网 络 设备 。 当 然 图 中 的 对 比 仅 能 起 到 一 般 意义 上 的 外 观 比 
较 ， 实 际 上 ， 因 为 交换 机 发 展 相 当 快 ， 其 应 用 向 两 个 不 同 的 方 同 发 
展 ， 所 以 在 外 观 上 也 有 很 大 的 区 别 。 小 的 加 面 交 换 机 束 像 我 们 现在 用 


的 Modem 一 般 大 (集线器 也 有 这 样 小 的 ， 而 大 的 则 采用 模块 化 结 
构 ， 机 箱 较 大 ， 而 不 古 像 图 中 显示 那样 像 一 个 长 方形 使。 图 5-37 所 示 代 
表 小 型 固定 端口 的 介面 型 交换 机 和 大 型 模块 化 交换 机 。 


图 5-37 小 型 固定 端口 交换 机 与 模块 化 交换 机 比较 


4 交换 机 的 主要 特性 


交换 机 (此 处 特 指 二 层 交 换 机 ) 是 上 市 介绍 的 网 桥 的 升级 产品 ， 
同样 是 工作 在 网 络 体系 结构 中 第 二 层 (数据 链 路 层 ) 。 但 它 与 网 桥 相 
比 义 具有 一 些 特性 ， 具 体 体 现在 以 下 儿 个 方面 : 


(1) 具有 多 个 交换 端口 


我 们 知道 网 桥 通 芝 只 是 两 个 交换 端口 ， 其 设计 目的 主要 就 是 用 来 
连接 两 个 距离 超过 单 段 网 线 传输 限制 的 物理 网 段 (当然 也 可 以 用 来 直 
接连 接 两 台 主 机 ) ， 所 以 它 的 应 用 受到 比较 多 的 限制 。 再 加 上 当时 用 
于 主机 和 其 他 网 络 设备 集中 连接 的 设备 仍 是 传输 效率 和 信道 利用 率 都 
非常 低下 的 集 线 侨 ， 根 本 不 适应 于 计算 机 网 络 的 发 展 。 有 了 交换 机 


后 ， 一 台 区 换 机 可 以 有 多 个 病 口 ， 而 且 与 网 桥 一 样 ， 不 仅 每 个 端口 可 
以 连接 一 个 不 同 的 物理 网 段 (交换 机 上 一 个 端口 对 应 一 个 物理 网 
段 )， 还 可 以 有 大 量 的 端口 来 集中 连接 主机 ， 这 时 交换 机 就 可 以 同时 
担当 集 线 胡 和 网 桥 的 双重 角色 ， 而 且 在 使 用 性 能 和 扩展 性 能 、 交 换 性 
能 等 方面 都 有 较 大 提高 ， 大 大 促进 了 计算 机 网 络 的 发 展 。 


(2) 数据 转发 效率 更 高 


在 网 桥 时 代 ， 集 中 连接 主机 的 仍 是 集 线 右 ， 而 我 们 知道 集 线 船 发 
送 数 据 是 采用 广播 方式 ， 所 以 信道 中 的 无 效 载荷 比例 相当 高 ， 造 成 数 
据 转 发 率 和 信道 利用 率 都 非常 低 。 而 有 了 交换 机 后 ， 因 为 大 多 数 主机 
都 古 直 接连 接 在 交换 机 端口 上 ， 即 使 不 十， 也 主要 是 连接 在 其 他 交换 
机 端口 ， 所 以 数据 的 转发 基本 上 都 旦 通过 提取 帧 中 的 MAC 地 址 直接 发 
送 到 目的 主机 上 的 ， 而 不 是 通过 广播 方式 〈 仅 在 未 知 目的 MAC 地 址 时 
采用 广播 ) ， 数 据 转发 效率 和 信道 利用 率 都 大 幅 提高 。 


(3) 更 强 的 MAC 地 址 自动 学 习 能 


我 们 知道 ， 网 桥 通 第 只 有 两 个 端口 ， 仪 可 以 连接 两 个 由 集 线 退 集 
中 连接 的 物理 网 段 ， 所 以 它 的 MAC 地 址 自动 学 习 功 能 仅 限于 它 的 两 个 
端口 与 对 应 的 物理 网 段 的 映射 。 这 样 吏 造 成 了 ， 一 个 网 桥 问 口 要 与 多 
个 源 主机 MAC 地 址 之 间 的 上 映射， 也 束 是 一 对 多 映 味 关系。 而 交换 机 上 
的 端口 多 数 是 直接 连接 主机 的 ， 所 以 在 映 味 表 中 基本 上 部 是 一 个 源 主 


机 MAC 地 址 与 一 个 交换 端口 则 的 一 对 一 映射 。 一 对 一 的 映射 诅 找 起 来 
明显 比 一 对 多 的 映射 效率 要 高 ， 所 以 交换 机 在 数据 转发 效率 要 高 于 网 
桥 。 男 外 ， 交 换 机 的 缓存 通常 比 网 桥 的 要 大 ， 所 以 交换 机 中 可 以 保存 
的 MAC 地 址 与 端口 映射 表 较 多 ， 更 适用 于 较 大 网 络 。 


2. 交 换 机 与 集 线 句 的 区 别 


交换 机 最 开始 是 为 了 解决 集线器 共享 传输 介质 、 端 口 带宽 过 罕 、 
容易 产生 广播 风 其 而 产生 的 。 最 初 的 交换 机 是 工作 在 OSI 开 放 体 系 结构 
中 的 第 二 层 ， 所 以 又 称 二 层 交 换 机 。 区 换 机 与 集 线 万 的 区 别 主 要 体现 
在 如 下 几 个 方面 : 


(1) 在 OSI 中 的 工作 层次 不 同 


交换 机 〈 特 指 二 层 交 换 机 ， 下 同 ) 和 集线器 在 OSI 开放 体系 模型 中 
对 应 的 层次 不 一 样 ， 集 线 器 工作 在 第 一 层 (物理 层 ) ， 而 交换 机 至 少 
征 工作 在 第 二 层 ， 更 高 级 的 交换 机 可 以 工作 在 第 三 层 〈 网 络 层 ) 、 第 
四 层 (传输 层 ) 和 第 七 层 (应 用 层 ) ， 对 应 也 就 有 三 层 交 换 机 、 四 层 
交换 机 、 七 层 交 换 机 等 之 说 了 。 本 章 仅 介绍 二 层 交 换 机 。 


(2) 数据 传输 方式 不 同 


集 线 右 的 数据 传输 方式 是 多 次 复制 方式 的 广播 传输 ， 而 交换 机 的 
数据 传输 是 有 目的 的 ， 数 据 只 对 目的 节点 发 送 ， 只 是 在 自己 的 MAC 地 


址 表 中 找 不 到 的 情况 下 第 一 次 使 用 以 FF-FF-FF-FF-FF-FF 作 为 MAC 地 址 
的 “ 泛 洪 ”广播 方式 传输 。 所 以 ， 交 换 机 在 数据 传输 效率 和 信道 利用 率 
方面 要 远 高 于 集线器 ， 人 集线器 更 容易 产生 “广播 风暴 ”。 


(3) 背 板 信道 占用 方式 不 同 


在 这 宽 占 用 方面 ， 集 线 器 所 有 站 口 都 十 共享 集 线 右 背 板 中 的 一 条 
信道 带宽 ， 而 交换 机 的 每 个 端口 的 收 、 发 都 有 独 主 的 背 板 信道 市 宽 ， 
属于 “交换 "方式 。 这 样 一 来 更 进一步 使 得 交换 机 的 数据 传输 效率 以 及 


传输 性 能 要 远 高 于 集线器 。 


(4) 数据 通信 方式 不 同 


集线器 因为 是 所 有 问 口 共享 一 条 背 板 信道 ， 所 以 只 能 采用 半 双 工 
方式 进行 传输 ， 同 一 时 间 ， 要 么 是 接收 数据 ， 要 么 是 发 送 数 据 。 而 交 
换 机 中 各 端口 的 信道 是 采用 和 矩阵 交换 方式 ， 可 以 同时 进行 数据 交换 ， 
也 束 是 可 以 进行 全 双 工 数据 传输 。 这 也 使 得 交换 机 比 集 线 融 的 数据 通 


信 效 率 要 远 高 于 集线器 。 


3. 交 换 机 的 分 类 


性 能 越 强 的 设备 ， 应 用 越 广 ， 这 也 导致 了 该 设备 的 技术 不 断 发 
展 ， 基 于 各 种 不 同 应 用 的 设备 类 型 也 越 多 。 交 换 机 融 是 这 样 一 种 应 用 
非常 广泛 的 网 络 设备 ， 它 自 最 初出 现 至 今 ， 各 种 不 同 的 交换 机 类 型 不 


断 涌现 ， 令 人 目不暇接 。 下 面 介 绍 一 些 目 前 仍 广泛 应 用 的 交换 机 分 类 
方式 。 


(1) 根据 网 络 类 型 划分 


根据 交换 机 所 应 用 的 局 域 网 类 型 可 以 将 局 域 网 交换 机 分 为 标准 以 
太 网 交换 机 (10Mbps 传 输 速 率 ) 、 快 速 以 太 网 交换 机 (100Mbps 传 输 
速率 ) 、 千 兆 以 太 网 交换 机 (1000Mbps 传 输 速 率 ) 、 十 千 兆 以 太 网 交 
换 机 (10000Mbps 传 输 速率 ) 等 。 


(2) 按 交 换 机 结构 划分 


如 琳 按 交换 机 结构 来 划分 的 话 ， 交 换 机 可 分 为 固定 端口 交换 机 和 
模块 化 交换 机 两 种 。 固 定 问 口 顾名思义 吏 是 它 所 带 有 的 端口 是 固定 
的 。 例 如 ， 如 有 果 有 是 8 站 口 的 ， 那 融 最 多 只 能 接 8 个 设备 ， 不 能 再 添加 
如 朱 生 16 个 端口 的 也 束 只 能 有 16 个 端口 ， 不 能 再 扩展 ， 以 此 类 推 。 目 
前 这 种 固定 端口 的 交换 机 基本 上 都 属 较 低档 次 的 。 模 块 化 交换 机 上 束 
征 交 换 机 上 除了 有 部 分 固定 的 端口 外 ， 还 可 通过 插入 扩展 模块 ， 来 扩 
展 端口 数量 、 所 文 持 的 传输 介质 /网 络 协 议 /业务 类 型 。 图 5-38a、b 所 示 
分 别 为 一 笋 固定 问 口 交换 机 和 一 款 模 块 化 交换 机 。 


a) 固定 端口 b) 模块 化 


图 5-38 固定 痢 口 交换 机 和 模块 化 交换 机 示例 


(3) 按 是 否 文 持 网 管 功能 划分 


按 交 换 机 是 否 文 持 网 络 管理 功能 可 以 将 交换 机 划分 为 网 管 型 和 非 
网 管理 型 两 大 类 。 网 管 型 交换 机 可 以 通过 控制 端口 (Console) 或 Web 
界面 进行 配置 与 管理 ， 非 网 管 型 交换 机 则 不 能 进行 任何 配置 与 管理 ， 
仅 可 按照 出 上 的 默认 设置 进行 工作 ， 也 融 是 通 音 所 说 的 傻瓜 型 交换 
机 名 


从 外 观 上 基本 上 可 以 判断 一 个 交换 机 是 否 具 有 网 管 功能 ， 因 为 网 
管 型 交换 机 都 有 一 个 Console 控 制 端口 ， 一 般 为 RS 一 一 232 串 口 型 的 
(也 有 用 普通 的 RJ 一 45 接 口 的 ， 但 会 有 一 个 Console 标 注 的 字样 ) 。 图 
5-39 所 示 为 一 个 带 有 RS 一 一 232 控 制 端口 的 网 管 型 交换 机 。 


“这 束 是 用 于 网 管 
232 控制 端口 ee 


图 5-39 网 管 型 交换 机 


5.8.4 ”二 层 交 换 原 理 


二 层 交 换 机 与 前 面 介绍 的 网 桥 一 样 ， 也 是 工作 在 OSI 参 考 模型 的 数 
据 链 路 层 ， 可 以 直接 根据 帧 中 的 目的 MAC 地 址 把 数据 发 送 给 相应 端口 
上 连接 的 主机 。 在 二 层 交 换 机 中 也 有 用 于 数据 帧 转发 的 MAC 地 址 与 端 
口 的 映射 表 (也 就 是 前 面 所 说 的 CAM 表 ) ， 列 出 了 哪个 MAC 地 址 连接 
的 是 哪个 端口 。 当 在 映射 表 中 没有 数据 帧 中 对 应 的 目的 MAC 地 址 时 才 
进行 “ 泛 洪 ”( 以 复制 方式 在 除 源 端口 外 的 其 他 所 有 端口 上 进行 转 
发 ) 。 但 是 要 注意 ， 交 换 机 缓存 空间 毕竟 有 限 ， 可 以 存储 的 MAC 地 址 
和 端口 映 射 表 项 也 限 ， 所 以 当 网 络 比 较 大 时 交换 机 中 的 缓存 空间 就 不 
能 保存 网 络 中 所 有 节点 MAC 地 址 与 交换 机 端口 的 映射 关系 了 。 


1.CAM 表 的 建立 


交换 机 的 这 张 CAM 表 可 以 通过 多 种 方式 获得 ， 比 如 静态 配置 、 动 
仿 学 习 ， 针 对 多 播 还 可 以 通过 各 种 多 播 协 议 ， 比 如 IGMP 咒 探 、GMRP 
协议 等 方式 (注意 ， 多 播 转发 表 不 能 通过 学 习 获 得 ， 而 且 多 播 转发 项 
跟 普 通 转发 项 不 同 ， 跟 其 对 应 的 出 口 不 止 一 个 ， 而 是 一 个 出 口 集 
多 播 方面 的 具体 知识 参见 笔者 编著 的 《Cisco/H3C 交 换 机 高 级 配置 与 管 
理 技术 手册 》 一 书 ) 。 


在 进行 数据 转发 的 同时 ， 交 换 机 还 有 一 个 学 习 的 过 程 ， 它 包括 两 
个 方面 : @ 交 换 机 在 接收 到 数据 帧 时 会 把 其 中 的 源 MAC 地 址 提取 出 
来 ， 查 询 CAM 表 ， 看 CAM 表 中 是 否 有 针对 该 MAC 地 址 的 转发 项 ， 如 果 
没有 ， 则 把 该 MAC 地 址 和 接收 到 该 MAC 地 址 的 端口 绑 定 起 来 ， 插 入 
CAM 表 项 ， 这 样 当 接收 到 一 个 发 送 到 该 MAC 地 址 的 数据 帧 时 ， 就 不 需 
要 癌 所 有 端口 广播 ， 而 仅仅 回 这 一 个 端口 发 送 即 可 。 避 在 接收 到 的 数 
据 帧 中 目的 MAC 地 址 未 知情 况 下 ， 通 过 向 交换 机 上 其 他 所 有 端口 进行 
广播 ， 接 收 广播 帧 的 节点 应 答 广播 帧 后 ， 便 获知 了 原来 数据 帧 中 对 应 
的 目的 MAC 地 址 所 连接 的 病 口 ， 这 时 交换 机 又 会 把 该 MAC 地 址 与 所 连 
端口 的 对 应 表 项 插入 到 CAM 表 中 。 


注意 ”数据 帧 的 转发 是 依据 目的 MAC 地 址 查询 CAM 表 ， 而 CAM 表 
的 学 习 则 是 以 源 MAC 地 址 为 依据 的 。 但 要 注意 的 是 ， 交 换 机 动态 学 习 
的 CAM 表 项 并 不 是 一 成 不 变 的 ， 而 是 局 动 一 个 定时 郁 ， 当 该 定时 天 递 
减 到 零 时 ， 该 CAM 稍 项 逢 删除 。 每 使 用 一 次 该 CAM 表 项 进行 转发 ， 束 
恢复 定时 万 初始 值 。 


上 述 介 绍 是 在 没有 考虑 VLAN (虚拟 局 域 网 ) 的 情形 下 阐述 的 ， 现 
在 的 交换 机 一 般 都 实现 了 VLAN， 所 以 CAM 表 就 有 了 变化 ， 由 原来 的 
两 项 对 应 关系 (MAC 地址 与 所 连接 的 交换 端口 ， 变 成 了 三 项 对 应 关系 
(MAC 地 址 ，VLAN ID， 交 换 机 端口 ) ， 这 样 当 接收 到 一 个 数据 帧 的 


时 候 ， 交 换 机 就 要 同时 根据 数据 帧 的 目的 MAC 地 址 和 VLAN ID 两 项 来 
查询 CAM 表 ， 找 到 接口 后 把 该 数据 帧 转发 出 去 。 


如 果 交 换 机 根据 MAC 地 址 和 VLAN ID 查询 CAM 表 失败 ， 即 没有 该 
MAC 和 VLAN ID 的 对 应 关系 ， 则 交换 机 把 该 数据 帧 对 该 VLAN 包 合 的 
〈 除 接收 端口 以 外 的 ) 所 有 端口 进行 广播 。 但 如 果 只 根据 CAM 表 来 确 
定 一 个 VLAN 包 含 哪些 端口 ， 则 必须 志 历 整个 CAM 表 ， 这 样 如 果 CAM 
表 的 规模 非常 大 ， 则 查询 的 效率 非常 低 ， 所 以 一 般 的 交换 机 上 在 实现 
VLAN 了 时， 还 会 创建 男 外 一 张 表 ， 即 VLAN 配 置 表 。 该 表 包 含 了 VLAN 
ID 和 交换 机 上 所 有 端口 的 对 应 关系 ， 即 只 要 根据 VLAN ID 查 询 该 表 就 
可 以 找到 该 VLAN 包 含 的 所 有 端口 ， 这 样 在 进行 VLAN 内 广播 的 时 候 ， 
就 非常 容易 了 。 


2. 二 层 交 换 原 理 


因为 交换 机 有 多 个 端口 ， 可 直接 连接 主机 或 其 他 交换 机 。 当 数据 
帆 发 送 到 本 交换 机 所 连接 的 主机 时 ， 交 换 机 就 可 以 根据 帧 中 目的 MAC 
地 址 直接 把 数据 从 对 应 的 端口 上 发 送 到 所 连接 的 主机 上 。 如果 数据 发 
送 到 本 交换 机 所 连接 的 其 他 交换 机 上 的 主机 时 ， 则 本 交换 机 先 把 该 数 
据 帧 发 送 到 连接 到 对 应 交换 机 的 端口 上 ， 然 后 再 由 那 台 交 换 机 根据 目 
的 MAC 地 址 从 对 应 端口 上 发 送 到 目的 主机 上 。 


总 体 来 说 ， 二 层 交 换 原 理 与 网 桥 的 数据 交换 原理 差不多 ， 具 体 如 
图 5-40 所 示 “。 不 同 的 只 是 现在 的 交换 机 端口 通 向 不 是 连接 集 线 郁 ， 而 是 
直接 交换 机 和 主机 ， 所 以 在 每 个 端口 所 连接 的 物理 网 段 中 也 采用 数据 
交换 方式 ， 而 不 采用 集线器 那样 的 复制 类 型 的 广播 方式 。 下面 进行 具 
体 的 解析 。 


在 CAM 表 中 记录 帧 
中 的 源 MAC 地 址 与 所 
连接 的 交换 机 端口 


收 到 数据 帧 


CAM 表 中 
是 否 有 源 MAC 
地 址 ? 


在 除 源 端口 外 的 其 他 所 
有 端口 上 泛 洪 该 数据 帧 


CAM 表 中 
是 否 有 目的 MAC 
地 址 ? 主机 MAC 地 址 与 帧 中 目的 MAC 

一 致 的 主机 接收 该 帧 ， 同 时 向 

源 主机 返回 一 个 帧 。 交 换 机 截 
自 按 根据 目的 MAC 地 址 获 应 答 帧 后 可 得 知 该 MAC 地 址 
把 数据 发 送 到 目的 主机 与 所 连 交 换 机 端口 的 映射 关系 


在 交换 机 CAM 表 中 添加 对 
应 MAC 地 址 与 所 连接 的 交 
换 机 端口 的 映射 表 项 


图 5-40 二 层 交 换 原 理 


1) 当 交 换 机 从 某 个 端口 收 到 一 个 数据 帧 后 ， 先 读 取 帧 头 部 的 源 
MAC 地 址 ， 并 与 自己 缓存 中 的 映射 表 (CAM 表 ) 进行 比较 ， 如 果 没 有 
找到 ， 则 在 CAM 表 中 添加 一 个 该 源 MAC 地 址 与 发 送 该 帧 的 源 端口 映射 
表 项 。 这 就 是 交换 机 的 MAC 地 址 自动 学 习 功 能 。 


2) 如 果 在 CAM 表 项 查 到 了 帧 中 源 MAC 地 址 ， 则 继续 查看 是 否 有 
炭 中 目的 MAC 地 址 所 对 应 的 映 喘 表 项 。 如 末 有 ， 则 直接 把 该 帧 转发 到 
目的 MAC 地 址 节点 所 连接 的 交换 机 端口 ， 然 后 由 该 端口 发 送 到 目的 主 
机 。 


3) 如 果 在 交换 机 CAM 表 中 没有 找到 帧 中 目的 MAC 地 址 所 对 应 的 
表 项 ， 则 把 该 数据 巾 回 除 源 问 口 外 的 其 他 所 有 闪 口 上 进行 沁 洪 。 


4) 当 MAC 地 址 与 帧 中 目的 MAC 地 致 的 主机 接收 了 该 数据 帧 后 就 
会 向 源 主机 产生 一 个 应 答 帧 ， 交 换 机 获取 该 应 答 帧 后 从 其 中 的 源 MAC 
地 址 中 获取 了 对 应 的 MAC 地 址 和 所 连接 端口 的 映射 关系 ， 并 添加 到 
CAM 表 中 。 这 样 下 次 再 有 MAC 地 址 为 这 个 MAC 地 址 的 帧 发 送 时 交换 机 
就 可 以 直接 从 CAM 表 中 找到 对 应 的 转发 端口 ， 直 接 转 发 ， 不 用 再 泛 潜 
了 o 


第 6 章 ”介质 访问 控制 子 层 


介质 访问 控制 子 层 (MAC 子 层 ) 是 局 域 网 体系 结构 中 划分 的 子 

层 ， 对 于 广播 型 网 络 〈 如 以 太 局 域 网 、WLAN) 是 非常 重要 的 ， 因 为 
它 担负 了 两 方面 的 主要 职责 : 一 是 如 何在 局 域 网 内 寻 址 (也 就 是 找到 
目的 节点 ) ， 二 是 如 何 解 决 多 路 通信 中 介质 争 用 的 现象 。 在 非 广播 型 
的 点 对 点 网 络 (广域网 基本 上 属于 点 对 点 网 络 ， 但 像 卫星 通信 类 的 网 
络 仍 属于 广播 型 网 络 ) 中 ， 却 不 存在 这 两 个 问题 ， 因 为 点 对 点 网 络 
中 ， 目 的 节点 是 唯一 的 ， 不 需要 寻 址 ， 而 且 双 方 之 间 的 通信 也 只 在 彼 
此 之 间 发 生 ， 没 有 其 他 用 户 使 用 这 个 介质 ， 所 以 也 不 存在 介质 争 用 现 
象 。 也 正 因 如 此 ， 本 章 所 介绍 的 内 容 主 要 适用 于 局 域 网 ， 包 括 以 太 局 
域 网 和 WLAN 无 线 局 域 网 。 


本 章 首 先 会 分 析 局 域 网 中 的 信道 类 型 ， 然 后 介绍 MAC 子 层 的 各 方 
面 功 能 和 技术 实现 原理 (如 CSMA、CSMA/CD 介 质 访问 控制 原理 ) ， 
后 面 主要 介绍 各 以 太 网 体系 结构 、 规 范 和 帧 格式 封 朔 ， 主 要 IEEE 802 
局 域 网 标准 (如 IEEE 802.1d、IEEE 802.1q、IEEE 802.1w 、 IEEE 802.1s 
和 IEEE 802.1x) 工作 原理 ， 最 后 综合 介绍 各 主要 WLAN 规 范 、 


CSMA/CA 原 理 和 WLAN 帧 格式 封装 。 


6.1 MAC 子 层 基 础 


MAC 于 层 是 有 线 局 域 网 体系 结构 和 WLAN 体 系 结构 中 数据 链 路 层 
的 一 个 子 层 。 它 有 两 个 主要 作用 ， 一 是 用 来 寻 址 (这 里 是 MAC 地 
址 ) ， 也 就 是 寻找 目的 节点 ; 二 是 用 来 解决 网 络 中 多 个 用 户 争 抢 共享 
物理 介质 或 者 共享 信道 的 现象 。 如 在 总 线 型 局 域 网 中 ， 所 有 或 者 多 个 
用 户 计算 机 连接 在 一 条 总 线 上 ， 不 同 用 户 计 算 机 间 的 通信 肯定 会 存在 
介质 争 用 现象 。 


经 验 之 谈 大 家 干 万 不 要 认为 仅 有 完全 的 总 线 型 拓扑 结构 网 络 才 
有 介质 争 用 现象 发 生 ， 其 实 只 要 网 络 存在 "总线 ” 部 分 ， 也 就 是 只 要 网 
络 中 存在 可 能 有 多 个 用 户 通过 同一 条 介质 访问 同一 个 玉 氮 ， 吕 存在 介 
质 争 用 。 即 使 在 最 简单 的 星 型 结构 单元 以 太 网 中 ， 也 会 存在 介质 争 用 
现象 ， 因 为 每 个 用 户 计算 机 与 交换 机 的 连接 都 是 通过 一 条 电缆 进行 
的 ， 网 络 中 可 能 有 多 个 其 他 用 户 要 同时 访问 该 用 户 。 在 企业 网 络 中 主 
要 使 用 的 树 型 结构 以 太 网 中 ， 这 种 介质 争 用 现象 就 更 普遍 了 ， 因 为 不 
同 交 换 机 之 间 的 连接 也 通常 是 通过 一 条 级 连 (Uplink) 电缆 进行 的 ， 这 
样 两 个 交换 机 之 间 用 户 的 访问 融 都 必须 通过 这 一 条 级 连 电 绕 ， 介 质 争 
用 吏 更 不 可 避免 了 。 有 关 这 儿 种 拓扑 结构 连接 原理 ， 大 家 可 以 参见 第 1 
章 的 相关 内 容 。 


在 Intemet 的 TCP/IP 协 议 体 系 结构 中 没有 MAC 子 层 ， 因 为 在 TCP/IP 
协议 体系 结构 中 主要 描述 的 是 广域网 中 的 “通信 子 网 * 部 分， 在 这 部 分 
主要 设备 就 是 各 种 广域网 路 由 器 (一 般 没 有 传统 的 以 太 网 交换 机 ) ， 


而 在 这 些 广域网 路 由 絮 之 间 的 连接 基本 上 痢 是 点 对 点 连接 的 ， 不 存在 
寻 址 ， 也 不 存在 介质 争 用 现象 。 


6.1.1 两 种 信道 类 型 


说 下 MAC 子 层 就 不 得 不 提 到 信道 这 个 概念 ， 因 为 MAC 子 层 的 主要 
功能 之 一 束 古 为 了 解决 不 同 用 户 通 信 信 道 争 用 问题 。 但 是 ， 并 不 是 所 
有 网 络 痢 存在 信道 争 用 问题 ， 只 是 在 广播 类 型 网 络 中 存在 。 我 们 在 前 
面 束 介绍 了 ， 信 道 可 分 为 护 对 点 信 道 和 广播 信道 两 大 类 ， 对 应 后 对 点 
和 广播 两 种 链 路 ， 当 然 也 对 应 点 对 点 和 广播 这 两 种 网 络 类 型 。 


所 谓 点 对 点 信道 是 指 由 两 个 没有 经 过 任何 中 间 设 备 (也 就 是 两 设 
备 的 接口 是 “背靠背 ”连接 的 ) 的 节点 (也 就 是 通常 所 见 的 计算 机 网 
卡 ， 或 其 他 网 络 设备 端口 ) 间 构 成 的 信道 ， 如 图 6-1 所 示 。 但 这 还 需要 
看 链 路 上 封 汉 的 数据 链 路 层 协 议 而 是， 点 对 扩 信 道 古 要 封 泛 扣 对 上 扩 类 
型 的 数据 链 路 层 协议 (如 PPP 和 PPPoE 等 ) ， 所 构成 的 链 路 就 是 我 们 通 
常 所 说 的 后 对 点 链 路 。 
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图 6-1 点 对 点 信道 示例 


因为 点 对 点 链 路 两 器 的 和 点 只 与 对 方 丰 点 进行 连 搂 ， 所 以 不 存在 
寻 址 问题 。 如 图 6-2 所 示 的 网 络 中 ， 计 算 机 A 可 以 注意， 不 是 必须 ， 
因为 具体 还 要 看 所 封装 的 数据 链 路 层 协 议 ) 与 计算 机 B、 计 算 机 C、 计 
算 机 E 建 立 点 对 点 连接 ， 但 却 不 能 与 计算 机 D 建 立 点 对 点 连接 ， 因 为 计 
算 机 A 与 计算 机 D 之 间 建 立 连接 时 都 必须 经 过 一 个 中 间 设 备 (计算 机 
B， 或 者 计算 机 C， 或 者 计算 机 E) ， 就 不 属于 点 对 点 连接 了 。 计 算 机 E 
却 可 以 与 其 中 的 任何 一 台 计 算 机 建立 点 对 点 连接 。 注 意 ， 本 示例 中 ， 
每 全 计算 机 与 另 一 台 计 算 机 的 连接 都 是 通过 一 块 单独 网 卡 进行 的 ， 这 
里 的 点 对 点 链 路 是 在 两 台 计算 机 上 安装 的 两 块 计算 机 网 卡 之 间 建 立 
I 


图 6-2 点 对 点 连接 示例 


广播 信道 表现 为 一 个 信道 被 多 条 链 路 所 共享 〈 也 就 是 存在 共享 信 
道 ) ， 也 就 是 存在 物理 介质 共享 的 情况 ， 如 图 6-3 所 示 。 在 广播 信道 
中 ， 一 个 市 扩 发 运 的 数据 可 以 同时 被 多 个 市 点 接 收 到 ， 对 应 的 链 路 整 
是 “广播 链 路 ”。 当 然 这 里 也 要 根据 对 应 链 路 上 所 封装 的 数据 链 路 协议 
而 定 ， 最 典型 的 广播 型 数据 链 路 层 协议 束 是 我 们 经 利用 的 以 太 网 协议 
和 WLAN 协 议 。 在 这 些 广播 网 络 中 ， 一 个 用 户 发 送 的 一 个 广播 包 可 以 
通过 交换 机 广播 到 本 局 域 网 中 的 所 有 市 点 上 。 图 6-4 所 示 是 在 一 个 总 线 
型 网 络 中 ， 数 据 在 广播 信道 中 同时 间 多 个 市 点 传输 的 示例 。 


DE 广播 信道 


图 6-3 广播 信道 示例 


图 6-4 广播 数据 传输 示例 


从 以 上 分 析 可 以 看 出 ，MAC 子 层 仪 在 广播 型 网 络 (如 以 太 局 域 
网 、WLAN， 以 及 其 他 无 线 网 络 ) 中 有 用 ， 而 对 于 点 对 上 扩 型 网 络 中 下 
没有 存在 的 意义 了 ， 因 为 在 点 对 点 网 络 中 不 需要 寻 址 ， 也 不 存在 一 般 
意义 上 的 信道 争 用 问题 (即使 存在 ， 也 基本 上 可 通过 各 种 信道 复 用 技 
术 来 解决 ) 。 


6.1.2 MAC 子 层 概 壕 


局 域 网 (包括 令 牌 网 、 以 太 局 域 网 和 WLAN 等 ) 中 与 接 入 的 各 种 
传输 介质 相关 的 问题 都 放 在 MAC 子 层 来 解决 ， 而 且 MAC 子 层 还 负责 
在 物理 层 的 基础 上 实现 无 差错 的 通信 。 具 体 说 ，MAC 子 层 的 主要 功能 
包括 : MAC 帧 的 封装 与 拆 凶 (这 方面 已 在 第 5 章 有 详细 介绍 了 ) ， 实 
现 和 维护 各 种 MAC 协 议 (这 是 本 章 重 点 之 一 ) ， 比 特 流 差错 检测 (这 
方面 也 已 在 第 5 章 有 详细 介绍 了 ) ，MAC 寻 址 〈 这 也 是 本 章 重 点 之 


一 ) 等 。 


因为 数据 链 路 层 分 成 了 LLC 子 层 和 MAC 子 层 (LLC 子 层 与 上 面 的 
网 络 层 连接 ， 而 MAC 子 层 与 下 面 的 物理 层 连 接 ， 具 体 参 见 图 5-3) ， 
所 以 数据 链 路 层 有 两 种 不 同 的 数据 帧 一 一 LLC 帧 和 MAC 帧 。 不 过 ， 我 
们 通常 所 说 的 “ 帧 ”一 般 是 指 MAC 帧 ， 而 不 是 LLC 帧 。 因 为 从 上 层 来 的 
数据 包 ， 进 入 到 LLC 子 层 后 加 上 LLC 子 层 的 协议 头 和 协议 尾 就 形成 了 
LLC 帧 ， 然 后 需要 继续 向 下 传输 ， 到 达 MAC 子 层 后 同样 再 要 加 上 MAC 
子 层 的 协议 头 和 协议 尾 ， 又 要 进行 重新 封装 ， 最 终 形成 MAC 帧 传输 到 
物理 层 。 对 于 物理 层 来 说 ， 最 终 的 数据 链 路 层 帧 就 是 MAC 幅 。 


由 于 IEEE 802 系 列 局 域 网 标准 中 规定 了 不 同 的 MAC 子 层 协议 (对 
应 不 同 的 网 络 标准 ) ， 所 以 其 MAC 帧 的 帧 格式 也 各 不 相同 (具体 将 在 


本 章 后 面 介 绍 ) ， 但 不 管 是 哪 一 种 MAC 协 议 ， 都 具有 MAC 地 址 ， 以 
便 在 局 域 网 内 部 实现 二 层 寻 址 。 


经 验 之 谈 在 同一 网 段 的 局 域 网 内 部 的 网 络 是 不 需要 通过 三 层 的 
IP 地 址 来 寻 址 的 ， 可 直接 通过 二 层 MAC 地 址 。 但 要 注意 的 是 这 里 所 说 
的 二 层 寻 址 仅 用 于 二 层 网 络 设备 之 间 的 网 络 通信 ， 不 能 作为 用 户 网 络 
应 用 通信 的 寻 址 ， 因 为 来 自 应 用 层 的 数据 在 传输 到 达 对 方 应 用 层 时 ， 
最 终 依靠 的 不 是 这 里 所 说 的 MAC 地 址 ， 而 是 网 络 层 的 也 地址 、 传 输 层 
的 端口 和 应 用 层 的 用 户 进程 。 无 论 是 在 局 域 网 内 部 ， 还 是 在 不 同 网 络 
之 间 的 数据 通信 都 是 如 此 。 在 一 个 局 域 网 内 部 ， 网 络 层 的 功能 是 由 安 
装 在 用 户主 机 中 的 网 络 操作 系统 提供 的 〈 因 为 在 一 个 局 域 网 内 部 没有 
路 由 器 设备 )  ， 由 主机 对 来 自 应 用 层 的 用 户 数 据 进行 三 层 封 效 。 千 万 
不 要 认为 ， 在 局 域 网 内 部 进行 网 络 应 用 就 不 需要 网 络 层 及 以 上 各 层 。 
只 是 纯 二 层 的 网 络 通信 ( 仅 用 于 构建 数据 通信 所 需 的 数据 链 路 ， 不 参 
与 用 户 应 用 数据 的 处 理 ) 不 需要 网 络 层 及 以 上 各 层 ， 要 进行 具体 的 网 
络 应 用 仍然 需要 网 络 层 及 以 上 各 层 的 功能 。 


在 局 域 网 中 ，MAC 地 址 的 作用 就 是 用 来 找到 我 们 要 进行 通信 的 计 
算 机 ， 网 卡 从 网 上 每 收 到 一 个 MAC 帧 ， 首 先 检 查 其 MAC 地 址 ， 如 果 
是 发 往 本 忆 点 的 帧 获 收 下 ， 然 后 进行 其 他 处 理 。 但 MAC 地 址 只 能 在 数 
据 链 路 层 识 别 ， 在 三 层 (网 络 层 ) 上 是 不 能 识别 的 ， 必 须 依 靠 ARP 映 
射 表 来 查找 对 应 的 目的 MAC 地 址 。MAC 帧 有 以 下 三 种 : 


口 单 播 帧 一 一 目的 MAC 地 址 是 一 个 单 播 MAC 地 址 的 帧 ; 


口 广播 帧 一 一 目的 MAC 地 址 是 一 个 广播 MAC 地 址 (全 “1” 地 址 ) 
的 帧 ; 


口 多 播 帧 一 一 目的 MAC 地 址 是 一 个 多 播 MAC 地 址 (多 MAC 地 址 
有 又 许多 种 ， 具 体 参 见 笔者 编著 的 《Cisco/H3C 交 换 机 高 级 配置 与 管理 
技术 手册 》 一 书 ) 的 帧 。 


6.1.3 ”介质 争 用 综 壕 


在 6.1.1 闻 说 了 ， 厂 播 型 网 络 中 就 存在 介质 争 用 现象 ， 其 实 这 束 涉 
及 一 个 概念 一 一 冲突 域 。 什 么 是 冲突 域 呢 ?其 实 也 就 十 可 能 发 生 介 质 
访问 冲突 的 节操 范围 。 这 时 我 们 要 分 析 两 种 在 局 域 网 中 经 党 用 到 的 设 
备 一 一 集线器 (Hub) 和 交换 机 (Switch) ， 通 过 对 它们 的 数据 传输 原 
理 介绍 来 帮助 理解 冲突 域 。 


1. 理 解剖 突 域 


首 移 来 看 一 人 Hub， 在 它 中 间 的 背 板 写 以 总 线 方式 连接 各 个 端口 
的 ， 如 图 6-5 所 示 。 从 图 中 可 以 看 ， 在 Hub 中 连接 的 所 有 用 户 都 是 通过 
共 至 一 个 背 板 信道 进行 访问 的 ， 所 以 连接 的 所 有 用 户 在 同时 访问 时 都 
可 能 发 生 冲 突 ， 所 以 我 们 说 一 个 集 线 紫 就 是 一 个 冲突 域 。 


6-5_ Hub 端口 与 背 板 的 总 线 连接 示意 


交换 机 (Switch) 的 背 板 与 端口 的 连接 方式 与 Hub 的 不 一 样 ， 在 背 
板 中 有 一 个 交换 和 矩阵， 如 图 6-6 所 示 。 通 过 交换 矩阵 ， 束 可 以 实现 任何 
两 个 端口 间 的 通信 都 有 一 条 专用 的 通道 ， 不 同 节 点 间 的 通信 不 存在 介 
质 争 用 现象 。 也 正 因 如 此 ， 在 交换机 中 的 冲突 域 吏 不 再 是 整个 交换 机 
了 ， 而 是 旨 小 到 一 个 具体 的 端口 了 ， 因 为 一 个 端口 连接 一 条 电 统 ， 而 
同时 可 能 有 多 个 用 户 要 与 这 个 端口 上 的 用 户 进 行 通信 ， 这 时 就 有 可 能 
发 生 介质 访问 冲突 了 。 


图 6-6 Switch 端口 与 育 板 板 窍 阵 连接 示意 匈 


打 个 比方 来 说 ， 在 一 条 十 字形 的 公路 上 ， 东 、 西 、 南 、 北 四 个 方 
回 的 车 是 不 可 能 同时 通过 的 ， 得 通过 区 通信 号 指示 灯 来 进行 指引 
一 段 时 间 仅 允许 相对 的 两 个 方向 (在 有 两 个 车 道 以 上 的 情况 下 ) 的 车 
通过 。 因 为 无 论 是 哪个 方向 的 车 通过 都 要 经 过 路 中 央 的 那个 地 方 ( 相 
当 于 集线器 的 背 板 信道 ) 。 但 是 如 果 建 个 了 立交桥， 甚至 多 层 的 立交 
桥 ， 并 规定 不 同方 向 的 车 走 不 同 的 桥 (相当 于 交换 机 中 的 背 板 交换 和 矩 
阵 ) ， 则 任何 方向 都 可 以 在 同一 时 间 通 车 了 。 


另外 ， 冲 突 域 是 有 大 小 的 ， 其 大 小 哆 是 可 能 共享 同一 介质 的 节点 
数 多 少 。 如 在 Hub 中 ， 端 口 数 越 多 ， 则 共计 同一 育 板 信道 的 用 户 数 越 
多 ， 冲 突 域 吏 越 大 ， 发 生 介质 争 用 的 可 能 性 束 越 高 ， 可 能 造成 的 冲突 


也 越 大 。 当 然 ， 神 突 的 大 小 还 与 集线器 或 交换 机 背 板 带宽 的 大 小 有 
天 ， 背 板 带 宽 越 蜗 ， 数 据 通过 的 速率 就 越 高 ， 发 生 冲 突 的 可 能 性 就 越 
低 ， 冲 突 就 越 小 。 就 像 同时 过 一 座 桥 的 人 越 多 ， 发 生 拥挤 的 可 能 也 整 
越 高 ， 但 如 有 果 桥 面 越 完 ， 人 允许 同时 过 这 个 桥 的 人 数 束 越 多 ， 发 生 拥挤 
的 可 能 也 惑 越 低 。 


2. 介 质 争 用 解决 方法 


既然 存在 介质 争 用 现象 ， 目 然 瑟 得 想 办 法 来 解决 ， 否 则 冲突 一 
多 ， 卓然 会 导致 数据 的 丢失 ， 或 者 畸变 。 束 像 一 群 人 要 同时 过 一 座 桥 
一 样 ， 如 果 人 数 过 多 ， 目 然 束 会 有 人 挤 人 的 现象 ， 甚 至 有 人 修 挤 挥 到 
桥 下 的 危险 。 但 是 ， 不 同 网 络 ， 所 采用 的 共 至 介质 争 用 解决 方法 也 不 
一 样 o 


我 们 在 学 习 前 面 IBM 令 牌 环 网 络 和 令 牌 总 线 网 络 时 吏 说 过 ， 在 这 
两 种 看 似 都 是 采用 共 宇 介质 的 令 牌 网 络 中 却 不 存在 介质 争 用 现象 ， 原 
因 束 是 它们 采用 了 “ 令 牌 "控制 原理 。 束 是 在 这 两 种 网 络 中 ， 用 户 必 须 
得 到 网 络 中 唯一 的 “ 令 牌 ”才能 发 送 数 据 。 显 然 同一 时 间 只 有 一 个 用 户 
节点 可 以 得 到 这 个 令 牌 ， 避 免 了 介质 争 用 现象 的 发 生 ， 尽 管 网 络 中 各 
用 户 古 共 至 这 一 条 介质 的 。 束 像 许 多 人 要 从 两 个 方 同 过 一 座 独 木 桥 ， 
如 果 桥 边 有 管理 员 ， 并 规定 每 个 人 过 桥 时 都 必须 先 征 得 管理 员 同 意 才 
能 过 桥 (也 就 是 等 一 人 过 完 后 男 一 个 人 才能 过 桥 ) ， 这 样 就 不 可 能 发 
生 拥 挤 现象 了 ， 尺 管 这 条 桥 很 罕 ， 一 次 仅 允 许 一 人 通过 。 


完 后 另 


管 这 


那么 其 他 存在 介质 访问 冲突 的 网 络 中 又 是 如 何 解决 介质 争 用 现象 
呢 ? 在 广域网 中 ， 通 音 是 采用 各 种 对 应 的 信道 复 用 技术 来 解决 ， 如 我 
们 前 面 介绍 的 FDM 信 道 复 用 技术 天 是 把 一 条 高 市 宽 的 信道 划分 成 市 视 
较 小 的 多 个 信道 ， 这 样 就 可 以 同时 进行 多 路 通信 了 ， 束 像 在 一 条 公路 
上 划分 多 个 小 车 道 一 样 ， 可 以 同时 通过 多 部 小 车 一 样 ，TDM 信 道 复 用 
技术 是 通过 把 不 同 路 通 信 的 数据 包 分 配 在 不 同时 除 进 行 传 输 来 实现 信 
道 复 用 的 。 


在 我 们 常用 的 以 太 局 域 网 和 WLAN 无 线 局 域 网 的 介质 争 用 解决 方 
案 主要 有 : CSMA、CSMA/CD 和 CSMA/CA 协 议 ， 后 两 者 是 前 者 的 改 
进 版 本 ， 在 此 先 介 绍 在 以 太 局 域 网 中 使 用 的 CSMA 和 CSMA/CD， 适 用 
于 WLAN 的 CSMA/CA 将 在 本 章 后 面 介绍 。 


6.2 CSMA 介 质 访 问 控制 原理 


在 总 线 型 网 络 中 ， 每 个 站 点 都 能 独立 地 决定 帧 的 发 送 〈 没 有 主 站 
点 和 从 站 点 之 分 | ， 很 显然 ， 如 有 条 两 个 或 多 个 站 点 同时 癌 总 线 上 发 送 
帧 ， 就 会 产生 介质 访问 冲突 〈 仅 指 在 没 采用 信道 复 用 情况 下 ) ， 导 致 
所 发 送 的 帧 出 错 。 因 此 ， 在 这 种 总 线 型 网 络 中 ， 一 个 用 户 数据 发 送 的 
成 功 与 否 ， 很 大 程度 上 取决 于 发 送 数据 时 是 否 会 与 其 他 用 户 发 送 的 数 
据 产 生 总 线 介 质 争 用 。 这 时 束 需 要 一 种 能 有 效 避 让 冲突 发 生 的 技术 ， 
确保 每 个 站 点 在 向 总 线 上 发 送 数 据 时 ， 其 他 站 点 均 不 发 送 数 据 ， 也 就 
征 如 何 使 各 个 站 点 能 尽快 地 检测 到 总 线 介质 是 否 空间 。 本 世 所 介绍 的 
CSMA (载波 侦 听 多 路 访问 ) 就 是 这 样 一 种 能 比较 有 效 解决 总 线 型 网 络 
中 介质 和 争 用 的 技术 。 


CSMA 技 术 又 称 LBT (Listen Before Talk， 先 听 后 说 ) ， 也 就 是 先 
侦 昕 要 访问 的 介质 ， 当 发 现 介 质 忙 时 先 避 让 一 段 时 间 ， 不 发 送 数 据 ， 
仅 当 侦 听 到 介质 空 几 时 才 进 行 数据 发 送 。 在 这 里 涉及 一 个 问题 ， 就 是 
在 站 点 侦 听 到 当前 信道 中 有 数据 在 传输 时 ， 要 避让 多 长 时 间 才 再 次 侦 
听 ， 这 束 古 CSMA 技 术 的 退 吉 算法 。 但 CSMA 可 以 采用 的 退 避 算法 有 几 
种 ， 也 可 算是 对 应 类 型 的 CSMA ， 那 就 是 : 非 -坚持 CSMA (no 
persistent CSMA) 、1- 坚 持 CSMA (1-persistentes CSMA) 、P- 坚 持 
CSMA (P-persistant CSMA) 。 下 面 对 这 些 算法 进行 具体 介绍 。 


6.2.1” 非 -坚持 算法 


非 -坚持 中 的 “ 非 ” 的 意思 就 是 指 各 站 点 不 连续 侦 听 总 线 介 质 是 否 空 
闲 ， 即 在 发 现 介质 忙 时 ， 先 停止 侦 听 ， 等 过 一 段 时 间 再 来 侦 听 。 具 体 
来 讲 ， 非 -坚持 CSMA 吏 是 某 站 点 发 现 总 线 介 质 上 没有 数据 在 传输 时 
(处 于 闲 状 态 ) ， 立 即 发 送 在 等 待 发 送 的 数据 ， 如 果 检 测 到 总 线 介 质 
上 有 数据 在 传输 时 〈 处 于 忙 状 态 ) ， 则 等 竺 一 段 时 间 再 来 侦 听 ， 再 忙 
时 再 等 待 一 段 时 间 来 侦 听 ， 以 此 类 推 ， 直 到 发 现 总 线 介 质 处 于 空闲 时 
本 站 点 才 可 发 送 数据 。 


图 6-7 所 示 的 就 是 一 个 非 -坚持 CSMA 介 质 访问 控制 示例 。 示 例 中 茶 
站 点 准备 要 发 送 一 个 数据 帆 Fi。 它 第 一 次 检测 时 发 现 忌 线 是 处 于 忙 状 
仿 ， 于 古 阳 了 一 段 时 间 t 后 ， 再 来 侦 昕 ， 发 现 总 线 介 质 还 十 处 于 忙 状 
候 ， 于 是 它 再 隅 一 段 时 间 t 来 侦 听 ， 终 于 在 第 三 次 侦 听 时 发 现 总 线 介 
质 是 处 于 闲 状态 ， 于 是 这 个 站 点 立即 把 Fi 帧 发 送出 去 。 


站 点 侦 听 到 人 忙 状 再 次 侦 听 到 忙 状 侦 听 到 闲 状 态 ， 
me 上 态 ， 等 待 4 时 态 ， 再 次 等 待 。 立即 发 送 Fi 帧 
于 后 再 侦 听 时 间 后 再 侦 听 
加 时间 b 上 时间 
a 


待 发 送 的 Fi 帧 


图 6-7 非 - 坚 持 CSMA 介 质 访问 控制 示例 


这 时 大 家 可 能 已 经 有 疑问 了 ， 那 束 古 这 个 非 - 坚 持 CSMA 和 站 法 中 ， 
在 上 次 侦 听 发 现 介质 处 于 忙 状 态 时 需要 等 待 多 长 时 间 再 来 侦 听 介质 的 
状态 呢 ? 答案 下 不 固定 的 ， 这 个 等 竺 的 时 间 且 根 据 非 -坚持 CSMA 算 法 
随机 产生 的 〈 具 体 产 生机 制 大 家 可 不 必 深 究 ) 。 如 果 采 用 TDM (时 分 
复 用 ) 传输 方式 ， 则 这 个 延迟 时 间 就 是 一 个 时 队长 度 。 


虽然 非 -坚持 CSMA 算 法 可 以 在 一 定 程 度 上 减少 冲突 的 发 生 ， 但 还 
征 不 能 完全 消除 冲突 的 发 生 ， 因 为 毕竟 每 个 站 点 发 送 的 数据 速度 不 一 
样 ， 数 据 在 信道 中 传输 是 需要 时 间 的， 而 且 等 待 的 时 间 也 不 一 定 就 可 
以 满足 一 个 帧 完全 传输 完毕 ， 所 以 尽管 每 个 站 点 都 是 在 检测 到 介质 至 
闲 时 才 发 送 数据 ， 但 仍 可 能 存在 前 一 个 由 还 在 信道 中 传输 时 ， 后 一 个 
站 点 的 帆 束 退 上 来 了 ， 进 而 发 生 冲突 。 


另外 ， 非 -坚持 CSMA 算 法 还 存在 一 个 明显 的 缺点 ， 这 融 是 一 旦 侦 
听 到 介质 忙 束 马上 延迟 一 个 随机 时 间 再 重新 侦 听 ， 但 很 可 能 在 再 次 侦 
听 之 角 信 道 吏 已 经 空间 了 。 也 束 是 非 - 坚 持 CSMA 不 能 把 信道 刚 一 变 成 
空闲 的 点 找 出 ， 影 响 了 信道 利用 率 的 提高 。 所 以 这 种 算法 主要 适用 于 
小 型 的 总 线 ， 或 者 树 型 拓扑 结构 网 络 中 ， 不 适用 于 像 现在 大 型 的 树 型 
结构 以 太 网 中 。 为 了 克服 这 一 缺 操 ， 可 采用 下 面 介绍 的 两 种 坚持 
CSMA 。 


6.2.2 1- 坚持 算法 


1- 坚 持 中 的 “1 有 两 层 侣 义 : 一 是 指 发 现 总 线 介 质 忙 时 一 直 持 续 不 
间断 侦 听 ， 直 到 发 现 介 质 处 于 朵 状态 ;二 十 在 侦 听 到 介质 处 于 至 朵 状 
态 后 一 定 〈 也 就 是 100%) 发 送 数据 。 前 面 介绍 的 非 -坚持 CSMA 算 法 古 
在 发 现 介质 忙 后 ， 即 随机 等 待 一 个 延 时 ， 然 后 继续 侦 听 ， 发 现 介 质 处 
于 内 状态 后 立即 发 送 数 据 ， 而 此 处 的 1- 坚 持 CSMA 算 法 中 是 在 发 现 介质 
忙 时 不 等 待 ， 继 续 侦 听 ， 一 有 旦 发 现 空 朵 即 立 即 发 送 数据 ;在 数据 传送 
过 程 中 发 生 冲 突 时 放弃 当前 的 数据 传送 任务 ， 等 待 一 个 延 时 后 再 继续 
倾听 。 


图 6-8 所 示 的 是 一 个 1- 坚 持 CSMA 介 质 访问 控制 示例 。 示 例 中 某 站 
点 准备 要 发 送 一 个 数据 帧 Fi。 它 第 一 次 检测 时 发 现 总 线 是 处 于 忙 状态 ， 
是 继续 侦 听 (不 等 待 ) ， 第 二 次 侦 听 发 现 总 线 介质 还 是 处 于 忙 状 
态 ， 于 是 它 再 继续 侦 听 ， 一 直到 第 n 次 侦 听 时 才 发 现 总 线 介质 是 处 于 朵 
状态 ， 于 是 这 个 站 点 立即 把 Fi 帧 发 送出 去 。 


页 昕 到 人 忙 ” 侦 昕 到 忙 。” 侦 听 到 忙 
状态 ， 继 ”状态 继 状态， 继 侦 听 到 闲 状 态 ， 
续 侦 听 续 侦 听 续 侦 听 立即 发 送 Fi 帧 


图 6-8 1- 坚持 CSMA 介 质 访问 控制 应 用 示例 


很 明显 ， 这 种 算法 相对 前 面 介 绍 的 非 -坚持 算法 来 说 的 优点 束 古 提 
高 了 介质 的 利用 率 ， 每 个 站 点 都 在 抓 住 一 切 有 利 时 机 发 送 数据 ， 因 为 
在 没有 发 生 神 突 时 是 无 须 等 待 一 个 随机 时 延 就 立即 进行 继续 侦 听 ， 不 
会 出 现 介质 处 于 空 闪 状态 仍 没有 站 后 发 送 数 据 的 情况 。 但 是 ， 该 算法 
仍 有 两 个 致命 的 弱点 : 一 是 在 有 多 个 站 点 发 送 数据 的 情况 下 ， 这 种 曼 
\ 等 符 的 算法 ， 也 束 使 得 冲突 时 第 发 生 。 原 因 就 是 前 面 所 说 的 ， 可 能 
在 网 络 中 同时 有 多 个 站 点 在 同一 时 间 检 测 到 介质 空间 (因为 中 间 没 有 
一 个 延迟 ， 也 束 是 一 直 在 侦 听 介质 状态 ) ， 而 立即 进行 了 数据 发 送 ， 
所 以 更 容易 发 生 冲 突 。 二 古 这 种 算法 发 现在 介质 忙 时 一 直 侦 听 ， 占 用 
了 大 量 网 络 和 设备 资源 。 所 以 1- 坚 持 CSMA 算 法 也 仪 适用 于 小 型 的 总 线 
型 或 者 树 型 拓扑 结构 网 络 ， 不 适用 于 现在 大 型 的 树 型 结构 以 太 了 网。 


6.2.3”P- 坚 持 算法 


既然 前 面 介 绍 的 两 种 算法 都 存在 明显 的 不 足 ， 上 自然 就 会 有 人 继续 
后 面 的 开发 ， 于 是 就 生产 了 新 的 P- 坚 持 CSMA 退 避 算 法 。 其 实 ，P- 坚 持 
CSMA 算 法 是 前 面 介 绍 的 非 -坚持 CSMA 和 1- 坚 持 CSMA 这 两 种 算法 的 一 
种 折 中 算法 ， 取 两 者 的 长 处 ， 而 尽量 克服 了 两 者 的 不 足 。 


理解 P- 坚 持 CSMA 退 避 算 法 的 关键 丈 是 理解 其 中 的 P， 其 是 指 侦 听 
到 介质 空 帮 时 发 送 数 据 的 概率 〈 小 于 1， 也 就 是 小 于 1009%) ， 就 是 指 站 
所在 发 现 介质 空间 时 可 以 立即 发 送 数 据 的 概率 为 P， 也 就 是 不 一 定 (不 
是 100%) 发 送 数据 ， 还 有 (1-P) 概率 是 不 发 送 数据 。 其 目的 就 是 为 了 
避免 与 其 他 站 点 发 生 冲 突 。 


具体 来 讲 ，P- 坚 持 CSMA 算 法 的 具体 介质 访问 控制 方法 与 前 面 介绍 
的 1- 坚 持 CSMA 类 似 ， 也 是 在 侦 听 到 介质 处 于 忙 状 态 时 持续 侦 听 ， 当 侦 
听 到 介质 处 于 空闲 状 态 时 ， 此 时 站 点 却 不 一 定 马 上 发 送 数据 ， 根 据 概 
率 P (这 个 P 值 是 算法 事先 确定 好 的 ) 来 选择 发 送 数据 ， 而 在 另 一 个 
(1-P) 概率 的 时 候 ， 即 使 介质 处 于 空 帮 状态 ， 也 会 延迟 一 段 时 间 t (这 
个 t 是 指 端 到 端的 传播 延 时 ) 后 再 重新 侦 听 介质 状态 。 


上 上 面 所 说 的 传播 延 时 是 有 计算 公式 的 ， 具 体 如 下 : 


传播 延 时 (hs)= 两 站 点 间 的 距离 (m)= 信 号 传播 速度 (m/s) 


如 已 知 传播 距离 为 1000km， 信 和 号 在 介质 上 的 传播 速率 为 2x108 
m/s， 则 可 计算 出 它 的 传播 延 时 为 1000x1000m/(2x108 my/s)=0.005s 。 


这 里 最 难 理解 就是 P 概 率 了 。 打 个 比方 ,，P 为 0.8， 也 就 古 80% 的 空 
闲 状 态 下 是 可 以 立即 发 送 数据 的 ， 还 有 20% (1-P) 的 概率 是 不 发 送 数 
据 ， 要 延迟 一 个 {时 间 (也 就 是 传播 延 时 ) 再 来 侦 听 介质 状态 。 如 果 在 
某 段 时 间 中 ， 前 面 已 有 一 个 空 内 状态 下 没有 发 送 数 据 ， 则 下 一 个 空闲 
状态 下 就 很 可 能 会 立即 发 送 数据 了 (毕竟 有 80% 的 可 能 性 十 要 发 送 数 据 
的 ) ， 否 则 如 果 前 面 连续 儿 个 空 内 状态 下 都 立即 发 送 了 数据 ， 则 下 一 
个 空 内 状态 下 束 可 能 不 发 送 数 据 了 。 忌 体 来 说 ,是否 发 送 数 据 十 随机 
的 ， 没 有 固定 哪个 空 朵 状态 下 必须 发 送 数据 ， 或 者 不 发 送 数据 ， 但 整 
体 通信 过 程 中 在 空闲 状态 下 发 送 数据 的 概率 都 是 在 P 以 内 。 


图 6-9 所 示 的 是 一 个 P- 坚 持 CSMA 介 质 访问 控制 示例 。 示 例 中 某 站 
点 准备 要 发 送 一 个 数据 帧 Fi。 它 第 一 次 检测 时 发 现 总 线 是 处 于 忙 状 态 ， 
是 继续 侦 听 (不 等 待 ) ， 第 二 次 侦 听 发 现 总 线 介质 还 是 处 于 忙 状 
态 ， 于 是 它 再 继续 侦 听 ， 第 3 次 侦 听 时 发 现 总 线 介质 是 处 于 闲 状 态 ， 但 
根据 概率 计算 出 现在 不 能 发 送 数据 ， 于 是 等 待 一 个 时 间 后 ， 再 来 侦 听 
介质 状态 ， 到 第 4 次 侦 听 时 发 现 介质 还 是 处 于 空闲 状态 ， 根 据 概率 计算 
得 出 马上 可 以 发 送 数据 了 ， 于 是 把 Fi 帧 发 送出 去 。 


侦 听 到 闲 状 态 ， 但 根 “ 侦 听 到 闲 状态 ， 根 据 
侦 听 为 忙 ” 侦 听 为 忙 ” 据 概 率 不 发 送 数据 ， 概率 可 以 发 送 数据 
状态 ， 继 ”状态 , 继 等待: 时间 后 再 侦 听 了， 把 Fi 帧 发 送出 去 
续 侦 听 续 侦 听 0 TTT Ps 


: | . 
国 国 一 一 ~ 


总 线 介质 


待 发 送 的 Fi 帧 


图 6-9 P- 坚 持 CSMA 介 质 访问 控制 应 用 示例 


从 以 上 分 析 可 以 看 出 ，P- 坚 持 退 避 算 法 羡 一 种 既 能 像 非 -坚持 
CSMA 算 法 那样 减少 冲突 ， 又 能 像 1- 坚 持 CSMA 算 法 那样 减少 介质 空间 
时 间 的 折 中 方案 ， 也 束 是 综合 了 前 面 所 介绍 的 两 种 算法 的 优点 ， 以 实 
现 优 缺 操 互 补 。 


6.3 CSMA/CD 介 质 访 问 控制 原理 


在 上 区 介绍 的 CSMA 介 质 访 问 控制 中 ， 由 于 信道 传播 延 时 的 存在 ， 
即使 通信 双方 的 站 点 都 没有 侦 听 到 载波 信号 ， 在 发 送 数据 时 仍 可 能 会 
发 生 冲 突 ， 因 为 他 们 可 能 会 在 检测 到 介质 空闲 时 同时 发 送 数据 ， 致 使 
冲突 发 生 。 尽 管 CSMA 可 以 发 现 冲 突 ， 但 它 并 没有 先知 的 冲突 检测 和 阻 
止 功能 。 而 本 节 要 介绍 的 CSMA/CD (Carrier Sense Multiple Access with 
Collision Detection， 载 波 侦 听 多 路 访问 /冲突 检测 ) 技术 却 有 具有 冲突 检 
测 和 阻止 功能 ， 它 是 CSMA 技 术 的 改进 版 本 。 


CSMA/CD 是 标准 以 太 网 、 快 速 以 太 网 和 千 兆 以 太 了 网 中 统一 采用 的 
介质 争 用 处 理 协 议 〈 但 在 万 兆 以 太 网 中 ， 由 于 采用 的 是 全 双 工 通信 ， 
所 以 不 再 采用 这 一 协议 ) 。CSMA/CD 的 最 大 亮点 就 是 它 在 侦 听 到 有 冲 
突 发 生 时 〈 同 时 有 多 路 数据 发 送 时 ， 信 和 号 强度 肯定 不 一 样 ) ， 可 以 立 
即 中 止 数据 帧 的 发 送 ， 快 速 地 终止 被 破坏 的 帧 可 以 节省 时 间 和 带宽 ; 
并 且 发 送 一 个 阻塞 信和 号， 以 强化 冲突 ， 使 其 他 站 点 更 容易 检测 到 有 冲 
突 的 发 生 ， 不 再 同时 发 送 数 据 了 ， 可 避免 更 多 的 帧 发 生 冲 突 。 


6.3.1 CSMA/CD 原 理 综 壕 


CSMA/VCD 的 介质 访问 控制 原理 包含 四 个 处 理 内 容 : 侦 听 、 发 送 、 
今 测 、 冲 突 处 理 ， 可 以 用 以 下 几 句 话 来 概括 : 


口 先 听 后 说 〈《“ 听 ?是 指 侦 听 , “说 ”是 指 发 送 数据 ， 下 同 ) ， 边 听 边 
说 ; 


口 一 旦 冲突 ， 立 即 停 说 ; 


口 等 行 时 机 ， 然 后 再 说 。 


具体 解释 如 下 (可 参见 图 6-10 所 示 的 示例 ) : 


1) 当 一 个 站 点 想 要 发 送 数据 的 时 候 ， 它 首先 要 检测 总 线 介质 上 是 
否 有 其 他 站 点 正在 传输 ， 即 侦 听 介 质 是 否 空闲 (也 就 是 前 面 所 说 的 “ 先 
yi”) 。 


2) 如 果 信道 念 ， 则 继续 侦 听 ， 直 到 侦 听 到 介质 状态 为 空闲 ， 如 果 
侦 听 到 介质 状态 为 空闲 ， 站 点 就 准备 好 要 发 送 的 数据 (也 就 是 前 面 所 
说 的 "后 说 ”) 。 


3) 在 发 送 数据 的 同时 ， 站 点 继续 侦 听 总 线 介质 〈 也 就 是 前 面 所 说 
的 “ 边 听 边 说 ") ， 确 信 没 有 其 他 站 点 在 同时 传输 数据 才 继续 传输 数 
据 。 因 为 有 可 能 两 个 或 多 个 站 点 都 同时 检测 到 介质 空 几 ， 然 后 几乎 在 
同一 时 刻 开 始 传输 数据 。 如 采 两 个 或 多 个 站 点 同时 发 送 数据 ， 束 会 产 
生 冲 突 。 奢 无 冲突 则 继续 发 送 直 到 发 完全 部 数据 。 


4) 大 检测 到 有 冲突 ， 则 立即 停止 发 送 数 据 〈 也 束 是 前 面 所 说 
的 “一 旦 神 突 ， 立 即 停 说 ") ， 同 时 发 送 一 个 用 于 加 强 冲 突 的 JAM ( 阻 
塞 ) 信号 ， 以 便 使 网 络 上 所 有 站 点 都 知道 网 上 发 生 了 冲突 ， 不 再 接收 
原来 的 师 ， 转 而 接收 这 个 阻塞 帆 。 本 站 点 然后 等 待 一 个 预定 的 随机 时 
间 (也 就 是 前 面 所 说 的 “等 待 时 机 ”) ， 且 在 总 线 为 空 亲 时 ， 再 重新 发 
送 数 据 (也 就 是 前 面 所 说 的 “然后 再 说 ”) 


站 点 | 国 | 侦 听 到 介质 为 
i [em 一 空闲 状态 立即 i i 
寺 人 关 的 B 失言 扎 届 wy va 下。 于 改 庶 阳 塞 信 呈 由 
nn 侦 听 为 忙 ” 俩 听 为 忙 发 送 Ei 帧 , 同 生得 可 且 0 


TT 


状态 , 继 状态 , 继 ”时 
续 侦 听 ” 续 侦 听 : 


待 发 送 的 Fi 帧 


检测 到 发 
: 溃 突 


总 线 介 质 下 


图 6-10 CSMA/CD 介 质 访问 控制 应 用 示例 


有 人 将 CSMA/CD 的 工作 原理 形象 地 比喻 成 很 多 人 在 一 间 黑 屋子 中 
举行 讨论 会 ， 参 加 会 议 的 人 都 是 只 能 听 到 其 他 人 的 声音 ， 看 不 到 人 。 
会 议 中 规定 ， 每 个 人 在 说 话 前 必须 先 倾听 ， 只 有 等 会 场 安静 下 来 后 ， 
他 才能 够 发 言 。 这 时 ， 可 将 人 们 在 发 言 前 进行 的 侦 听 (以 确定 是 否 已 
有 人 在 发 言 ) 的 动作 比喻 为 CSMA/CD 的 载波 侦 听 ， 将 在 会 场 安静 的 情 
况 下 每 人 都 有 平等 机 会 讲话 比喻 为 CSMA/CD 的 多 路 访问 。 如 果 有 两 人 
或 两 人 以 上 同时 说 话 ， 大 家 就 无 法 听 清 其 中 任何 一 人 的 发 言 ， 这 种 情 


况 称 为 发 生 冲 突 ， 发 言 人 在 发 言 过 程 中 要 及 时 发 现 是 否 发 生 冲 突 ， 这 
个 动作 称 为 冲突 检测 ;如 果 发 言 人 发 现 冲突 已 经 发 生 ， 这 时 他 需要 停 
止 讲话 ， 然 后 随机 后 退 延 迟 ， 再 次 重复 上 述 过 程 ， 直 至 讲话 成 功 。 如 
果 失 败 次 数 太 多 ， 他 也 许 束 会 放弃 这 次 发 言 的 想法 。 


6.3.2 ”冲突 检测 原理 


为 了 确保 所 有 站 点 在 发 送 数据 的 站 点 发 送 完 数据 前 开始 接收 数 
据 ， 以 太 网 定 了 一 个 最 小 帧 (这 个 最 小 帧 的 有 效 载 奏 不 能 少 于 46 字 
节 ) ， 最 小 帧 的 大 小 与 网 络 分 布 的 距离 、 传 输 介 质 类 型 和 到 达 目 的 节 
点 前 所 使 用 的 中 继 强 数量 等 有 天 。 综 合 这 些 因素 专家 们 定义 了 一 个 公 
认 值 一 一 以 太 网 时 际 ， 为 10Mbps 速 率 下 传输 512 位 数据 所 用 的 时 间 ， 即 
51.2hs。 


当 有 两 个 或 多 个 正在 传输 数据 的 站 点 检测 到 它们 发 送 的 数据 发 生 
了 冲突 时 ， 它 们 都 会 通过 发 送 一 个 阻塞 帧 〈 它 是 一 个 32 位 全 为 1 的 帧 ) 
来 进行 啊 应 。 下 面 以 一 个 示例 来 插 述 CSMA/CD 的 冲突 检测 原理 。 


1) 一 开始 (t=0 时 ) ， 站 点 A 在 介质 空 采 时 发 送 一 个 帧 ， 如 图 6-11 
所 未 = 


A 站 点 开始 数据 传输 


图 6-11 站 点 A 开 始 发 送 数据 


2) 一 段 时 间 后 ， 在 站 后 A 传输 的 数据 帆 还 没 到 达 站 点 B 前 ， 站 斥 B 
也 可 能 检测 到 介质 为 空 帮 的， 于 是 也 开始 进行 数据 传输 ， 如 图 6-12 所 


当 A 站 点 正在 传输 数据 时 ， 
几 几 一 扎 一 喇 呵 B 站 点 也 开始 了 数据 传输 


图 6-12 站 点 B 也 开始 数据 传输 


3) 从 A 站 点 发 送 数据 开始 ， 过 一 段 时 间 后 (相当 于 站 点 A 到 达 站 
点 B 的 传播 延 时 bb ) ， 站 点 B 检 测 到 了 来 自 站 点 A 的 数据 ， 检 测 到 了 发 
生 了 冲突 ， 立 即 中 止 原来 的 数据 传输 ， 发 送 一 个 32 位 的 阻塞 信号 帧 。 
但 是 站 点 A 此 时 仍 还 不 知道 站 点 B 也 在 发 送 数据 ， 仍 不 知道 有 冲突 发 
生 ， 如 图 6-13 所 示 。 


TN B 站 点 检测 到 冲突 


图 6-13 站 点 B 检 测 到 冲突 


4) 再 过 了 相当 于 一 个 往返 传播 时 间 (也 就 是 目 站 点 A 发 送 数 据 开 
始 ， 过 了 两 个 传播 延 时 2t, ) 后 ， 从 站 点 B 发 来 的 阻塞 信号 帧 也 到 达 了 
站 点 A，A 也 知道 发 生 冲 突 了 ， 停 止 数 据 发 送 ， 如 图 6-14 所 示 。 此 时 站 


点 B 会 停止 阻塞 信号 帧 的 发 送 ， 而 站 点 A 又 会 发 送 一 个 阻塞 信号 帧 。 最 
后 ，A 和 B 都 停止 了 数据 发 送 ， 介 质 回归 空 帮 状态 。 


由 A 站 点 也 检测 到 冲突 


图 6-14 站 点 A 也 检测 到 冲突 


6.3.3 ”冲突 避让 原理 


CSMA/CD 除 了 可 以 检测 到 冲突 的 发 生 外 ， 还 可 以 在 冲突 发 生 时 进 
行 随 机 延迟 ， 以 尽量 避免 再 次 发 生 冲突 。 这 时 会 涉及 一 个 避让 延迟 问 
古 ， 也 就 是 当 检 测 到 冲突 时 ， 到 的 要 延迟 多 长 时 间 再 重 传 。 这 就 十 
CSMA/CD 的 截断 二 进 制 指数 退 避 算法 (truncated binary exponential 
backoff) 。 在 这 种 退 避 算法 中 ， 每 次 检测 到 冲突 时 避让 (也 就 是 名 称 
中 的 “截断 ”含义 ， 即 停止 发 送 数 据 ) 的 时 间 是 以 时 除数 为 单位 的 随机 
时 间 ， 但 不 同 次 冲突 时 所 能 延迟 的 最 大 时 除数 是 不 一 样 的， 而 且 是 呈 
晶 数 关系 递增 的 ， 所 以 才 称 之 为 二 进 制 指数 退 避 算法 。 因 为 当 出 现 线 
路 冲突 时 ， 如 采 冲 突 的 各 站 点 都 采用 同样 的 退 避 间隔 时 间 ， 则 很 容易 
产生 二 次 、 三 次 的 碰撞 。 


CSMA/CD 的 重 传 避让 流程 如 图 6-15 所 示 。 下 面 是 具体 的 解释 。 


1) 首先 ， 站 点 会 初始 化 当前 帧 的 重 传 次 数 N 为 0， 并 开始 侦 听 介质 
状态 。 如 有 果 介 质 处 于 忙 状态 ， 则 等 待 ， 在 等 到 介质 处 于 空 采 状态 后 再 
等 待 一 个 帧 间 发 送 间 际 的 时 间 (IFG， 为 9.6hs) ， 以 使 网 络 中 所 有 接收 
站 上 扩 有 时 间 准 备 好 接收 下 一 个 帧 。 


2) 然后 ， 站 点 开始 按 次 序 传送 帧 ， 同 时 继续 侦 听 介质 状态 。 


3) 如 果 传 到 某 个 帧 时 侦 听 到 发 生 了 神 突 ， 则 该 站 点 立即 停止 传 
输 ， 开 始 冲 突 处 理 流 程 ， 发 送 一 个 用 于 加 强 冲 突 的 阻塞 信号 ， 并 把 该 
央 的 重 传 次 数 N 速 增 1。 


4) 到 了 这 里 ， 束 要 对 N 值 进行 判断 了 ， 因 为 不 同 的 重 传 次 数 可 以 
延迟 的 时 际 数 不 一 样 。 因 为 如 有 果 所 有 站 点 在 发 生 冲 突 后 都 立即 重 传 ， 
则 肯定 又 会 发 生男 外 一 个 冲突 。 所 以 一 个 正确 的 流程 可 确保 一 个 同时 
重 传 的 情况 很 少 发 生 ， 在 以 太 网 中 所 采用 的 方案 束 是 使 用 一 个 随机 的 
避让 时 间 ， 使 每 个 站 点 选择 一 个 随机 数 来 乘 以 时 隙 长 度 《51.2hs) ， 在 
企图 重 传 前 必须 等 得 这 个 随机 的 时 长 。 


发 送 帧 ( N=0 ) 


天 到 区 
延迟 Rx 51.2 微 秒 在 0~ (2 -1 之 间 


随机 选择 一 个 整数 R 
A 延迟 再 检测 呈 


等 待 9.6hs 


传输 帧 


传输 32 位 阻塞 帧 


图 6-15 CSMA/CD 避 让 原理 示意 图 


发 生 冲 突 时 ，CSMA/CD 可 以 计算 出 重 传 的 次 数 (图 中 的 N) ， 并 
规定 当 N ( 重 传 次 数 ) 达到 15 时 ， 该 帧 会 被 直接 丢弃 ， 当 N 小 于 15 时 ， 
再 判断 N 是 否 s<10， 如 果 不 是 ， 则 把 K 的 值 置 为 10， 否 则 K=N， 然 后 根 
据 公式 Rx51.2hs 来 计算 要 延迟 的 时 间 。 其 中 R 是 在 0~2k -1 之 间 的 一 个 随 
机 整数 ， 而 K=N，N 为 传输 次 数 〈(K=N<10) 。 也 就 是 ， 每 个 帧 传输 的 
次 数 是 有 限制 的 ， 那 就 是 16， 即 N=15， 超 过 这 个 值 ， 则 会 直接 丢弃 这 
个 巾 ， 放 弃 再 次 重 传 ， 并 生成 一 个 日 志 。 通 常 在 一 个 负载 不 是 很 重 的 
网 络 中 ， 是 不 会 丢弃 帧 的 ， 因 为 很 难 有 重 传 15 次 后 仍 不 能 传输 成 功 
的 。 


每 一 次 重 传 ， 站 点 都 会 构建 一 组 可 以 选择 的 避让 时 除数 组 L0，1， 
2，3，4，5，...，L}， 其 中 L=2k -1， 且 K<10。 每 次 重 传 时 所 选择 的 避 
让 时 际 个 数 R 束 是 从 以 上 数组 中 选择 的 。 例 如 ， 在 发 生 两 次 冲突 后 ， 
N=2， 所 以 K=2， 得 到 的 数组 就 是 {0，1，2，3} (2 -1) ， 表 示 在 发 生 
两 次 冲突 后 ， 所 需 避 让 的 时 际 数 有 四 个 选择 ， 也 就 是 在 0~3 个 时 隙 中 选 
择 一 个 值 ， 即 {0，51.2hs，102.4hs，153.6hs}。 


图 6-16 所 示 就 是 以 上 发 生 两 次 冲突 时 的 避让 示例 。 首 先 ， 站 点 A 开 
始 进 行 数据 传输 ， 然 后 站 点 B 也 开始 数据 传输 ， 在 站 点 A 发 送 第 二 个 帧 
的 过 程 中 与 站 点 B 发 送 来 的 数据 发 生 冲 突 ， 此 时 站 点 A 和 站 点 B 都 会 生 
成 一 个 重 传 次 数 数组 {0，1} (因为 此 时 只 是 发 生 了 第 1 次 冲突 ，N=1， 


所 以 0~21 -1=0~1) ， 并 且 可 能 都 随机 选择 延迟 一 个 时 隙 再 发 送 数据 。 
站 点 A 和 站 点 B 在 延迟 一 个 时 隐 后 再 次 同时 发 送 数据 时 ， 再 次 发 生 剖 
突 。 此 时 站 点 A 和 站 点 B 都 会 重新 生成 一 个 重 传 延 迟 时 除数 组 L0，1， 
2，3} (因为 此 时 只 是 发 生 了 第 2 次 冲突 ，N=2， 所 以 0~2? -1=0~3) 。 但 
此 时 站 点 A 选择 延迟 的 时 隙 数 为 0， 也 就 是 不 延迟 ， 立 即 重 传 ， 而 站 点 
B 选 择 是 延迟 2 个 时 除数 后 再 重 传 数据 。 


' 县 “县 


重 传 延 迟 {0,1) 
时 隙 数组 


重 传 延迟 10 ， 3 
时 除数 组 


重 传 延迟 。 {0,1} 
时 隙 数组 


重 传 延迟 {0， 
时 隙 数组 


避让 时 际 


图 6-16 发 生 两 次 冲突 时 的 避让 示例 


同 理 ， 在 三 次 冲突 后 ，N=3， 可 选择 的 避让 时 阶 数 组 为 0，1，2， 
3，4，5，6，7} (23 -1) ， 也 就 是 可 以 在 等 待 尺 上 其 中 8 个 之 一 可 选 时 
隙 数 长 度 后 再 重 传 数 据 。 四 次 冲突 之 后 ，N=4， 可 选择 的 避让 时 阶 数 组 
为 {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15} (24 


-1) ， 也 就 是 可 以 在 等 待 以 上 其 中 16 个 之 一 可 选 时 隙 数 长 度 后 再 重 传 数 
据 。 


6.3.4 ” CSMA/CD 的 不 足 


使 用 CSMA/CD 介 质 访问 控制 的 一 个 缺点 束 是 ， 当 LAN 中 的 互 连 的 
每 台 计 算 机 都 只 有 少量 数据 需要 传输 时 ， 网 络 中 每 个 站 点 对 介质 的 共 
享 都 几乎 是 公平 的 ; 但 是 如 果 一 个 站 点 需要 发 送 大 量 的 数据 时 (如 一 
个 站 点 担当 高 质量 视频 源 的 情况 下 ) ， 这 时 就 可 能 出 现 一 个 站 点 长 时 
间 控 制 整 个 LAN 的 情形 。 如 图 6-17 所 示 ， 计 算 机 A 控制 着 计算 机 B。 最 
初 ， 两 台 计算 机 都 有 数据 在 传输 。A 先 进行 数据 传输 ， 然 后 A 和 B 同 时 
试图 传输 ， 发 生 了 冲突 。 此 时 B 选 择 了 一 个 比 A 更 大 一 些 的 等 待 时 际 数 
来 进行 重 传 。A 开 始 重 传 ， 这 时 有 一 个 短 时 间 的 暂停 ,然后 A 和 B 都 试 
图 恢复 传输 。 


加、 
“时 重 传 延 述 {Os 嫩 


时 隙 数组 


重 传 延 述 0 二 


重 传 延迟 {0,1) 
时 隙 数组 


时 际 数 组 


重 传 延 迟 {0, 1} 
时 隙 数组 重 传 延迟 ”{0, 1, 2, 3， 


时 隙 数组 4,，5，6,，7} 


重 传 延迟 ”1{0,1} 
时 陵 数 组 


图 6-17 一 个 站 点 控制 整个 LAN 共 至 介 质 的 示例 


6.4 ”局域网 标准 及 以 太 网 帆 格 式 


在 局 域 网 中 ， 绝 大 多 数 标准 都 是 由 IEEE (电气 和 电子 工程 师 协 
会 ) 802 委 员 会 制定 的 IEEE 802 系 列 标准 ， 其 中 在 企业 网 络 中 应 用 最 广 
的 就 是 以 太 局 域 网 标准 IEEE 802.3。 后 来 IEEE 802 系 列 标准 被 TSO 接 受 
为 正式 的 国际 标准 ， 标 准 名 为 ISO 8802 。 


6.4.1 IEEE 802 系 列 局 域 网 标准 


1985 年 IEEE 公 布 了 应 用 于 局 域 网 的 IEEE 802 标 准 文本 ， 同 年 为 美 
国 国家 标准 局 (ANSI) 采纳 作为 美国 国家 标准 。 后 来 ， 国 际 标准 化 组 
织 (ISO) 经 过 讨论 ， 建 议 将 802 标 准 定 为 局 域 网 国际 标准 。 目 前 ， 
IEEE 802 主 要 包括 的 标准 如 表 6-1 所 示 ， 在 许多 标准 中 义 有 许多 规范 ， 
就 像 IEEE 802.3 标 准 中 就 包括 了 许多 不 同 的 以 太 网 规范 一 样 ， 这 些 在 本 
章 后 面 再 具体 介绍 。 这 些 802 分 委员 会 标准 之 间 ， 以 及 各 自 与 OSI 参考 
模型 之 间 的 关系 如 图 6-18 所 示 。 


表 6-1 主要 IEEE 802 标准 


IEEE 802.1 局 域 网 概述 ， 局 域 网 体系 结构 ， 网 络 管理 和 网 络 互 连 
IEEE 802.2 逻辑 链 路 控制 LLC 
IEEE 802.3 CSMA/CD 总 线 介质 访问 控制 子 层 与 物理 层 规范 
IEEE 802.4 令 牌 总 线 (Token Bus) 介质 访问 控制 子 层 与 物理 层 规范 
IEEE 802.5 令 牌 环 〈Token Ring) 介质 访问 控制 子 层 与 物理 层 规范 
IEEE 802.6 城 域 网 (MAN) 介质 访问 控制 子 层 与 物理 层 规范 
IEEE 802.7 宽带 技术 咨询 和 物理 层 课题 与 建议 实施 
IEEE 802.8 光纤 技术 咨询 和 物理 层 课 题 
IEEE 802.9 综合 语音 /数据 服务 的 访问 控制 方法 和 物理 层 规范 
IEEE 802.10 局 域 网 安全 性 规范 
IEEE 802.11 无 线 局 域 网 访问 控制 方法 和 物理 层 规范 
IEEE 802.12 100VG-AnyLAN 星 型 快速 局 域 网 访问 控制 方法 和 物理 层 规范 
IEEE 802.14 协调 混合 光纤 同 轴 (HFC) 网 络 的 前 端 和 用 户 站 点 间 数 据 通 信 的 协议 
IEEE 802.15 无 线 个 人 网 技术 标准 ， 其 代表 技术 是 蓝牙 (Bluetooth) 
0SI 参 考 模型 
高 IEE 802.10 局域网 安全 
层 IEEE 802.1 体系 结构 、 网 络 管理 和 网 络 互 连 
IEEE 802.2 ”逻辑 链 路 控制 (LLC ) 
数据 
链 路 802.12 
层 
100VC- 
物理 层 。 AnyLAN 


物理 
规范 


图 6-18 IEEE 各 标准 之 间 ， 以 及 与 OSI 参考 模型 之 间 的 关系 


IEE 802.1、802.2、802.3、802.11 等 这 些 主要 局 域 网 标准 在 本 章 后 
面 有 专门 介绍 ， 其 他 局 域 网 标准 的 具体 功能 大 家 可 以 参考 其 他 资料 。 


6.4.2 ”以 太 网 帆 格 式 综 壕 


以 太 网 (Ethernet) 这 个 术语 一 般 是 指数 字 设 备 公司 (Digital 
Equipment) 、 英 特 尔 公司 (Intel) 和 施乐 公司 (Xerox) 在 1982 年 联合 
公布 的 一 个 标准 (实际 上 它 是 第 二 版 本 ， 即 Ethernet II， 第 一 版 本 早 在 
1972 年 就 在 施乐 公司 帕 洛 阿尔 托 研 究 中 心 PARC 里 产生 了 ) 。 


Ethernet II 采用 CSMA/CD 介 质 访 问 控制 方法 ， 传 输 速率 为 仅 10 
Mbps。1985 年 ，IEEE 《电子 电气 工程 师 协 会 ) 的 802 委 员 会 公布 了 一 
个 系列 的 以 太 网 标准 ， 其 中 802.3 专 门 针 对 以 太 网 、802.4 针 对 令 牌 总 线 
网 络 、802.5 针 对 令 牌 环 网 络 ， 但 这 三 种 网 络 的 共同 特性 由 802.2 标 准 来 
定义 ， 那 就 是 802 网 络 共 有 的 逻辑 链 路 控制 (LLC) 。 不 笠 的 是 ，802.2 
和 802.3 定 义 了 一 个 与 Ethernet I 以 太 网 不 同 的 帧 格式 ， 加 上 1983 年 
Novell 为 其 Netware 开 发 的 私有 帧 ， 这 些 给 以 太 网 造成 了 一 定 的 混乱 ， 
也 给 我 们 学 习 以 太 网 带 来 了 一 定 的 影响 。 


在 以 太 网 帆 格 陈 方 面 上 ， 主 要 有 过 以 下 的 六 种 。 在 此 先 仅 对 这 些 
以 太 网 帆 格 式 进行 价 单 介绍 ， 具 体 的 子 段 说 明 将 在 后 面 介绍 。 


(1) EthernetI 


这 是 最 原始 的 一 种 以 太 网 MAC 幅 格式， 是 由 Xerox 公 司 提 出 的 
3Mbps CSMA/CD 以 太 了 网 标准 的 封装 格式 ， 后 来 在 1980 年 由 DEC、Intel 


和 Xerox 三 家 公司 发 布 。 其 中 最 关键 的 一 个 字段 就 是 类 型 (Type) 字 
段 ， 以 便 它 可 以 文 持 多 种 网 络 层 协议 包 ， 如 TCP/IP 协 议 、IPX/SPX、 
Apple Talk 等 。 但 该 版 本 当时 应 用 并 不 广泛 ， 随 后 基本 被 新 的 Ethernet II 
版 本 取代 。 


(2) Ethernet II 


这 是 由 DEC、Intel 和 Xerox 三 家 公司 在 1982 年 发 布 的 ， 即 DIX2.0 的 
以 太 网 帧 格式 。 它 主要 更 改 了 Ethemet I 的 电气 特性 和 物理 接口 ， 在 帧 
格式 上 并 无 变化 ， 如 图 6-19 所 示 。 其 中 除数 据 字段 (46~1500 个 字 市 ) 
外 ， 其 他 均 为 MAC 子 层 的 协议 头 和 协议 尾 (此 时 并 没有 划分 LLC 子 
层 ， 所 以 没有 LLC 子 层 头 部 分 ) ， 最 小 帧 (包括 帧 头 和 帧 尾 ， 长 度 为 
64 字 节 ， 最 长 为 1518 字 节 。Ethernet II 出 现 后 迅速 取代 Ethemet I 成 为 以 
太 网 事实 标准 。 


6 6 2 46~1500 4 字 节 
目的 MAC 地址 源 MAC 地 址 


图 6-19 Ethernet II 帆 格 式 
(3) Ethernet 802.3 raw 


这 是 Novell 公 司 在 1983 年 公布 的 专用 以 太 网 标准 帧 格式 〈 仅 支持 
IPS/SPX 这 一 种 协议 ) 。 该 格式 以 当时 尚未 正式 发 布 (所 以 加 了 一 个 
raw， 就 是 “原始 "的 意思 ) 的 IEEE 802.3 标 准 为 基础 ， 具 体 的 帧 格式 如 


图 6-20 所 示 。 相 对 Ethernet II 幅 来 说 ， 就 是 多 了 一 个 2 字 市 的 0xXFFFF， 用 
于 标识 这 个 帧 是 Novell Ethernet 类 型 的 。 由 于 总 的 以 太 网 帧 最 小 和 最 大 
长 度 不 变 〈 仍 分 别 为 64 字 节 和 1518 字 节 ) ， 所 以 数据 字段 中 的 最 小 和 
最 大 长 度 也 相应 减 小 2 字 节 ， 为 44~1498 字 节 。 但 是 当 两 年 后 IEEE 正 式 
发 布 802.3 标 准时 ， 人 情况 发 生 了 变化 ， 因 为 IEEE 在 802.3 帧 头 中 又 加 入 了 
802.2LLC 头 ， 这 使 得 Novell 的 RAW 802.3 格 式 与 正式 版 的 IEEE 802.3 标 
准 互 不 兼容 。 


6 6 2 2 44-1498 4 字 节 
| 目的 MAC 地 址 源 MAC 地 址 长 度 | 0xFFFF | 数据 | FCS 


图 6-20 Ethernet 802.3 raw 帆 格式 
(4) Ethernet 802.3 SAP 


这 是 IEEE 在 1985 年 公布 的 Ethernet 802.3 的 SAP 版 本 以 太 网 帧 格 

式 ， 是 IEEE 发 布 的 第 一 个 以 太 网 帧 格式 版 本 ， 如 图 6-21 所 示 。SAP 是 服 
务 访问 点 的 意思 ， 表 示 添 加 了 LLC 帧 头 部 ， 包 含 目 的 服务 访问 点 
(DSAP) 、 源 服务 访问 点 (SSAP) 和 控制 (Control) 这 三 个 字段 。 
另外 ， 它 将 Ethernet II 帧 头 的 Type (类 型 字段 奉 换 为 帧 Length (长 
度 ) 字段 。 因 为 新 添加 了 DSAP、SSAP 和 控制 这 三 个 各 占 1 字 节 的 字 
段 ， 所 以 数据 字段 的 长 度 范围 也 要 相应 调整 为 43~1497 字 节 ， 这 也 是 类 
型 字段 的 取 值 范围 。 这 个 以 太 网 帧 格式 版 本 可 以 说 是 一 个 过 渡 版 本 ， 


因为 IEEE 在 后 面 很 快 又 进行 了 更 新 ， 相 继 发 布 了 802.3/802.2 LLC 和 
802.3/802.2 SNAP 版 本 。 


6 6 2 1 1 1 43 ~ 1497 4 字 节 


目的 MAC 地址 源 MAC 地 址 长 度 | DASP | SSAP | 控制 数据 FCS 


图 6-21 Ethernet 802.3 SAP 幅 格式 
(5) 802.3/802.2 LLC 


这 是 IEEE 1997 年 正式 发 布 的 802.3 标 准 ， 由 Ethernet 802.3 SAP 版 本 
发 展 而 来 ， 且 帧 格式 也 一 样 。 但 这 是 IEEE 正 式 划 分 LLC 子 层 后 的 第 一 
个 以 太 网 标准 ， 第 一 次 把 原来 DSAP、SSAP 和 控制 这 三 个 字段 当成 LLC 
头 o 


(6) 802.3/802.2 SNAP 


这 是 IEEE 为 保证 在 802.3/802.2 LLC 标 准 上 支持 更 多 的 上 层 协议 同 
时 ， 更 好 地 支持 IP 协 议 而 于 1998 年 发 布 的 扩展 以 太 网 帧 标准 。SNAP 
(SubNetwork Access Protocol， 子 网 访问 协议 是 一 种 可 以 传输 多 种 协议 
包 的 网 络 访问 协议 。 


与 802.3/802.2 LLC 帧 格式 一 样 ，802.3/802.2 SNAP 也 带 有 LLC 头 
(如 图 6-22 所 示 ) ， 但 是 扩展 了 LLC 属 性 : 一 是 新 添加 了 一 个 2 字 节 的 
类 型 字段 (注意 ， 此 类 型 字段 与 Ethermet I 版 本 中 帧 格式 的 类 型 字段 是 
不 一 样 的 )  ， 用 于 标识 更 多 的 上 层 协 议 类 型 ， 男 外 新 添加 了 一 个 3 字 节 


的 OUI (组 织 唯一 标识 ， 通 肖 是 全 为 0) 字段 ， 用 于 代表 发 布 所 选 上 层 
协议 的 组 织 。 同 样 因为 总 的 以 太 网 帧 最 小 和 最 大 帧 长 度 是 不 变 的 ( 仍 

分 别 为 64 字 节 和 1518 字 节 ) ， 除 了 数据 字段 外 ， 其 他 字段 的 总 长 为 26 

字 节 。 所 以 数据 字段 的 长 度 范 围 为 38~1492 个 字 节 ， 这 也 是 长 度 字段 的 
取 值 范围 。 


6 6 2 1 1 1 3 38~1492 4 字 节 


目的 MAC 地 址 | 源 MAC 地址 | 长 度 | DASP | SSAP | 控制 OUI ID 类 型 数据 FCS 


图 6-22 ”802.3/802.2 SNAP 帧 格式 


我 们 在 第 3 章 就 介绍 到 了 ， 从 应 用 层 发 送 来 的 PDU (协议 数据 单 
元 ) ， 每 经 过 一 层 都 要 把 上 层 发 送 来 的 整个 PDU 作 为 下 层 PDU 的 Data 
(数据 ) 字段 部 分 ， 然 后 在 其 前 面 加 上 对 应 层 的 协议 头 (Header) 和 
协议 尾 (Tail， 并 不 是 一 定 要 加 ) 。 


在 以 上 六 种 以 太 网 帧 格式 中 ，Ethernet I 、Ethernet II 和 Ethernet 
802.3 raw 这 三 种 以 太 网 帧 仅 包 含 MAC 帧 部 分 ， 而 在 正式 的 IEEE 802.3 
SAP 以 太 网 标准 发 布 后 ， 因 为 同时 发 布 了 LLC 子 层 的 IEEE 802.2 标 准 ， 
这 时 的 以 太 网 帧 格式 其 实 就 包括 了 MAC 帧 和 LLC 帧 两 部 分 了 。 来 自 网 
络 层 的 数据 包 到 达 数 据 链 路 层 后 要 经 过 LLC 和 MAC 这 两 个 子 层 的 两 次 
先后 封装 。MAC 帧 是 把 整个 LLC 帧 当成 Data 字 段 ， 然 后 再 加 上 上 自己 的 
MAC 帧 头 和 帧 尾 ， 就 构成 了 最 终 的 MAC 帧 ， 也 就 是 我 们 通常 所 说 的 以 
太 网 帧 ， 整 个 以 太 网 帧 的 封装 流程 如 图 6-23 所 示 。 


Data 


一 一 一 46~ 1500 字 节 一 一 一 + 


物理 层 


图 6-23 PDU 的 各 级 封装 方式 示意 图 


在 以 上 这 六 种 以 太 网 帧 格式 中 ， 曾 经 或 者 现在 主流 应 用 的 是 
Ethernet I、802.3/802.2 LLC 和 802.3/802.2 SNAP 这 三 种 ， 它 们 的 格式 对 


比如 图 6-24 所 示 ， 各 具体 字段 将 在 后 面 介绍 。 


Fthernet II Destination MAC| Source MAC Frame type Data ( 46 ~ GRG 
和 Address Address (IP, ARP) 1500 字 节 ) |Checksum 
CDE 《6 字 玉 ) (6 字 节 ) “| (2 字 节 ) (4 字 节 ) 


802.3 MAC Op CRC 
802.3 Header eke 季 Checksum 


( 802.3/802.2 LLC ) (14 字 节 ) (4 字 节 ) 


Destinalion Source MAC Length of Sourc Control 
MAC Address | Address the frame 
(6 字 节 ) (6 字 节 ) (2 字 节 ) 


802.3 MAC 头 802.2 LLC 头 


802.3 MAC 802.2 LLC 802.2 SNAP 
Data (38 -~ 
Header Header Header 1492 字 节 ) Checksum 
802.3 SNAP (14 字 节 ) (3 字 节 ) (5 字 节 ) (4 字 节 ) 


( 802.3/802.2 SNAP ) 


OUI (Organizationally 小 
ype 


Unique Id ) (2 字 节 ) 


(3 字 节 ) 


802.2 SNAP 头 


图 6-24 三 种 主要 以 太 网 帧 格式 比较 


6.4.3 ”以 太 网 LLC 帧 头 部 格式 


目前 说 的 以 太 网 帧 ， 通 常 都 会 认为 其 帧 头 和 帧 尾 包括 LLC 帧 头 、 
MAC 帧 头 和 MAC 帧 尾 这 三 部 分 。 上 和 节 就 已 说 到 ， 目 Ethernet 802.3 SAP 
以 太 网 标准 发 布 后 ， 在 以 太 网 帧 中 添加 了 802.2 LLC 帧 头 ， 这 一 点 也 可 
以 从 图 6-24 中 看 出 。 在 802.3 系 列 以 太 网 中 ，LLC 帧 头 格式 是 一 样 的 
( 共 3 字 节 长 度 ) ， 如 图 6-25 示 。 本 节 要 具体 解释 这 三 个 字段 的 含义 。 


] ] Ls 


图 。6-25 LLC 帧 头 部 格式 


DDSAP: 目的 服务 访问 点 (Destination Service Access Point) 字 
段 ， 指 示 数 据 接收 方 的 LLC 子 层 的 SAP， 占 1 字 节 (8 位 ) 。 在 以 太 网 
中 ， 该 字段 的 值 固定 为 十 六 进 制 的 0xAA。 


口 SSAP: 源 服 务 访问 点 (Source Service Access Point) 字段 ， 指 示 
数据 发 送 方 的 LLC 子 层 的 SAP， 占 1 字 节 (8 位 ) 。 在 以 太 网 中 ， 该 字段 
的 值 也 固定 为 十 六 进 制 的 0xAA 。 


口 欣 制 : Control 字 段 ， 用 于 指示 数据 链 路 层 所 用 的 服务 类 型 ， 占 1 
字 廊 (8 位 ) 。 在 以 太 网 中 都 是 采用 无 连接 服务 ， 所 以 固定 值 为 十 六 进 


制 的 0x03 。 


6.4.4 以 太 网 SNAP 头 部 格式 


从 图 6-24 可 以 看 出 ， 在 802.3/802.2 SNAP 以 太 网 帧 中 ， 除 了 添加 了 
3 字 节 的 LLC 头 部 外 ， 还 添加 了 5 字 贡 的 SNAP 头 部 作为 LLC 扩 展 部 分 ， 
如 图 6-26 所 示 。SNAP 头 部 包括 OUIID 和 类 型 这 两 个 字段 ， 本 节 将 具体 


解释 这 两 个 字段 的 含义 。 


3 2 字 节 


OUI ID 


图 6-26 SNAP 头 部 格式 


‘ty 


口 OUI: 组 织 唯一 标识 (Organizationally UniqueIdentifier) 字段 ， 
指示 帧 中 Data 字 段 数据 报 所 对 应 协议 的 发 布 公司 的 标识 ， 占 3 字 节 (24 
位 ) 。 如 果 是 IEEE 公 司 发 布 的 以 太 网 协议 类 型 ， 则 此 字段 固定 为 
0x000000。 


DType: 类 型 字段 ， 其 实 是 协议 ID 字段 ， 指 示 帧 中 数据 字段 数据 
报 所 对 应 协议 类 型 ， 占 2 字 节 〈16 位 ) 。 不 仅 文 持 在 以 太 网 MAC 帧 中 
Type 〈 类 型 ) 字段 中 所 支持 的 802.3 以 太 网 协议 ， 还 支持 802.4、802.5、 
802.11 和 其 他 802 系 列 协 议 ， 甚 至 文 持 像 FDDI (Fiber Distributed Data 
Interface， 光 纤 分 布 式 接口 这样 的 非 802 协 议 。 如 果 是 IEEE 公 司 发 布 


的 以 太 网 协议 类 型 ， 则 此 字段 的 值 根据 表 6-2 来 选择 。 有 关 这 些 协议 的 
具体 说 明 可 参见 其 他 相关 资料 。 


表 6-2 常见 以 太 网 类 型 协议 


协议 ID 以 太 网 协议 
0x0800 Internet Protocol, Version 4 (IPv4) 

0x0806 Address Resolution Protocol (ARP) 

0x0842 Wake-on-LAN Magic Packet 

0x1337 SYN-3 heartbeat protocol (SYNdog) 

0x22F3 IETF TRILL Protocol 

0x6003 DECnet Phase IV 

0x8035 Reverse Address Resolution Protocol (RARP) 
0x809B AppleTalk (Ethertalk) 

Ox80F3 AppleTalk Address Resolution Protocol (AARP) 
0x8100 VLAN-tagged frame (IEEE 802.1Q) 

Ox8137 Novell IPX (alt) 

0x8138 Novell 

Ox8204 QNX Qnet 

0x86DD Internet Protocol, Version 6 (IPv6) 

Ox8808 MAC Control 

Ox8809 Slow Protocols (IEEE 802.3) 

Ox8819 CobraNet 

Ox8847 MPLS unicast 

0x8848 MPLS multicast 

Ox8863 PPPoE Discovery Stage 

Ox8864 PPPoE Session Stage 

Ox886F Microsoft NLB heartbeat 中 

0x8870 Jumbo Frames 

0x887B HomePlug 1.0 MME 

Ox888E EAP over LAN (IEEE 802.1X) 

0x8892 PROFINET Protocol 

Ox889A HyperSCSI (SCSI over Ethernet) 

0x88A2 ATA over Ethernet 

Ox88A4 EtherCAT Protocol 

Ox88A8 Provider Bridging (IEEE 802.1ad) 

0x88AB Ethernet Powerlink 

Ox88CC LLDP 

Ox88CD sercos JJI 

0x88D8 Circuit Emulation Services over Ethernet (MEF-8) 
0x88E] HomePlug AV MME 


0x88E3 Media Redundancy Protocol (IEC62439-2) 


协议 ID 
0x88E5 
0x88F7 


0x8902 


0x8906 
0x8914 
0x9000 
0x9100 


以 太 网 协议 
MAC security (IEEE 802.1AE) 


Precision Time Protocol (IEEE 1588) 


IEEE 802.1ag Connectivity Fault Management (CFM) Protocol / ITU-T 
Recommendation Y.1731 (OAM) 


Fibre Channel over Ethernet 
FCoE Initialization Protocol 
Configuration Test Protocol (Loop)™ 


Q-in-Q 


6.4.5 ”以 太 网 MAC 帆 


MAC 帧 通常 被 认为 是 数据 链 路 层 帧 ， 是 在 MAC 子 层 实体 间 交 换 的 
协议 数据 单元 (PDU) 。 根 据 图 6-24 所 示 ， 可 以 把 所 有 以 太 网 MAC 帧 
的 格式 统一 表示 为 图 6-27 所 示 ， 前 面 两 节 介 绍 的 LLC 帧 头 和 SNAP 头 部 
与 上 层 来 的 数据 报 一 起 均 封 装 在 数据 字段 中 。 


6 2 38~1500 4 字 节 


前 导 (Preamble) 字段 占 7 个 字 节 ， 由 1 和 0 交互 构成 (如 
10101010......) ， 用 于 使 PLS 子 层 电路 与 收 到 的 帧 达到 时 钟 同步 。 


(2) 帧 起 始 


帧 起 始 (Start-of-Frame Delimiter，SFD) 字段 占 1 个 字 节 ， 前 6 位 也 
是 1 和 0 交互 构成 ， 最 后 两 位 是 连续 的 1， 即 10101011， 表 示 一 个 帧 的 开 
始 。 前 导 码 的 作用 是 使 接收 端 能 根据 1、0 交 互 的 比特 模式 迅速 实现 比 
特 同步 ， 当 检测 到 连续 两 位 1 《 即 读 到 帧 起 始 定 界 符 字段 SFD 最 末 两 
位 ) 时 ， 便 将 后 续 的 信息 递交 给 MAC 子 层 。 


说 明 在 以 上 两 个 字段 中 ， 在 早期 的 ntel 和 Xerox 公 司 开发 的 以 太 
网 标准 中 是 把 SFD 字 段 并 入 到 了 Pre 字 段 中 ， 所 以 那 时 的 MAC 帧 格式 中 
没有 SFD 字 段 。 只 有 后 面 由 IEEE 发 布 的 以 太 网 标准 中 才 出 现 了 SFD 字 
段 。 但 Pre 和 SFD 这 两 个 字段 只 是 用 来 提醒 接收 端 新 的 一 帧 到 来 了 ， 并 
不 计 入 MAC 幅 大 小 中 。 


(3) 目的 MAC 地 址 / 源 MAC 地 址 


目的 MAC 地 址 (Destination Address，DA) 和 源 MAC 地 址 
(Source Addresses，SA) 字段 各 占 6 个 字 节 ， 分 别 用 于 标识 接收 站 点 
的 MAC 地 址 和 发 送 站 点 的 MAC 地 址 。 它 们 可 以 是 单 播 MAC 地 址 ， 也 可 
以 是 组 播 地 址 或 广播 MAC 地 址 。 地 址 字段 最 高 位 为 0 表示 单 播 MAC 地 
址 ， 该 地 址 仅 指定 网 络 上 某 个 特定 站 点 ; 地 址 字段 最 高 位 为 1、 其 余 位 
不 为 全 1 表示 组 播 MAC 地 址 ， 该 地 址 指定 网 络 上 给 定 的 多 个 站 点 ; 地 址 

字段 为 全 1， 则 表示 广播 MAC 地 址 ， 该 地 址 指定 网 络 上 所 有 的 站 点 。 


(4) 长 度 /类 型 


长 度 /类 型 (Length/Type) 字段 是 一 个 二 选 一 字段 ， 也 就 是 对 于 具 
体 的 以 太 帧 来 说 ， 它 的 售 义 不 一 样 ， 占 2 字 节 。 在 Ethernet I 和 Ethernet II 
以 太 网 帧 中 ， 该 字段 为 类 型 (Type) 字段 ， 指 出 帧 中 数据 字段 中 的 数 
据 类 型 ， 这 些 类 型 的 值 如 表 6-2 所 示 ， 总 大 于 1536 (对 应 的 十 六 进 制 为 
0x600) ; 如 果 是 IEEE 802.3 (包括 Ethernet 802.3 raw、Ethernet 802.3 


SAP、802.3/802.2 LLC 和 802.3/802.2 SNAP) 以 太 网 帧 ， 则 该 字段 为 长 
度 (Length) 字段 ， 值 总 小 于 或 等 于 1500 (对 应 的 十 六 进 制 为 
0x5DC) 。 对 照 图 6-24 可 知 ， 在 IEEE 802.3 以 太 网 帧 中 ， 数 据 字 段 的 长 


度 为 38~1500 字 节 。 


说 明 上 面 的 DA、SA 和 LengthType 这 三 个 字段 组 成 MAC 帧 头 
部 。Pre 和 SFD 这 两 个 字段 通常 不 认为 是 MAC 幅 头 部 的 组 成 部 分 。 


(5) Data 


数据 (Data) 字段 对 于 不 同 的 以 太 网 帧 所 包括 的 内 容 也 不 一 样 ， 
对 于 Ethernet I、Ethernet II 和 Ethernet 802.3 raw 以 太 网 帧 ， 它 就 是 从 网 
络 层 来 的 数据 包 ; 而 对 于 Ethernet 802.3 SAP、802.3/802.2 LLC 和 
802.3/802.2 SNAP 以 太 网 帧 ， 则 是 LLC 帧 全 部 内 容 ， 包 括 LLC 帧 头 和 来 
自 网 络 层 的 数据 包 。 也 正如 此 , “数据 字段 长度 范围 也 各 不 一 样 ， 具 
体 如 下 〈 可 参见 图 6-19~ 图 6-22 中 的 数据 字段 字 节 范围 标注 ) : 


口 Ethernet I、Ethernet II 由 数据 字段 长 度 范围 为 46~1500 字 贡 ; 


口 Ethernet 802.3 raw 帧 数据 字段 长 度 范围 为 44~1498 字 有 ; 


口 Ethernet 802.3 SAP 和 802.3/802.2 LLC 帧 数据 字段 长 度 范围 为 


43~1497 字 节 : 


口 Ethernet 802.2 SNAP 帧 数据 字段 长 度 范 围 为 38~1492 字 节 。 


总 体 而 言 ， 该 字段 长 度 范围 为 38~1500 个 字 节 。 但 无 论 怎样 ， 总 的 
MAC 帧 长 度 最 小 为 64 字 节 ， 最 长 为 1518 字 节 (不 包括 “前 导 ” 字 段 和 “ 帧 
起 始 字段 >) ， 如 果 不 够 64 字 节 时 ， 要 在 “数据 ”字段 中 加 上 PAD 填 充 字 


段 。 


注意 ”这 里 所 说 的 38~1500 字 世 长 度 是 在 没有 经 过 IEEE 802.1Q 
VLAN 协 议 重 封装 时 的 长 度 范围 ， 如 果 封 装 了 VLAN 协 议 ， 则 因为 
VLAN 标 识 占 用 了 4 字 节 ， 所 以 就 整个 以 太 网 帧 来 说 ， 数 据 字 段 的 取 值 
范围 就 为 34~1500 字 节 。 有 关 IEEE 802.1Q VLAN 协 议 将 在 本 章 后 面具 


体 介 绍 。 
(6) Frame Check Sequence (FCS) 


帧 校 验 序列 (FCS) 字段 占 4 个 字 节 ， 包 括 32 位 的 循环 元 余 校 验 
(CRC) 值 ， 由 发 送 端 对 MAC 帧 自 DA 字段 到 Data 字 段 间 (不 包括 Pre 
和 SFD 这 两 个 字段 ) 的 二 进 制 序列 生成 校 验 和 ， 然 后 通过 接收 端 对 所 接 
收 的 帧 以 上 部 分 ( 自 DA 字 段 到 Data 字 段 间 ， 不 包括 Pre 和 SFD 两 个 字 
段 ) 进行 重新 计算 ， 看 两 次 校 验 的 结果 是 否 一 样 即 可 以 得 出 所 检验 的 
帧 在 传输 过 程 中 是 否 已 被 破坏 。 有关 CRC 校 验 原理 参见 第 4 章 。 


6.5 ”标准 以 太 网 规范 及 体系 结构 


目 本 市 开始 ， 束 要 全 面 、 系 统 、 深 入 地 介绍 我 们 天 天 打交道 的 以 
太 局 域 网 了 。10Mbps 以 太 网 是 第 一 个 真正 走 入 实质 应 用 的 以 太 网 标 
准 ， 尽 管 现在 早已 不 再 使 用 ， 但 是 后 面 的 所 有 以 太 网 标准 都 是 基于 这 
个 标准 改进 、 开 发 的 ， 所 以 我 们 还 是 很 有 必要 全 面 地 了 解 这 个 早期 的 
以 太 网 标准 。 


6.5.1 标准 以 太 网 规范 


标准 以 太 网 (也 就 是 十 兆 以 太 网 ) ， 以 及 后 面 将 要 介绍 的 快速 以 
太 网 ( 百 兆 以 太 网 ) 、 千 兆 以 太 网 和 万 兆 以 太 网 规范 都 是 在 IEEE 
802.3 家 族 标准 中 发 布 的。 本 市 先 介 绍 标准 以 太 网 。 


标准 以 太 网 最 初 使 用 的 是 同 轴 电 绕 作 为 传输 介质 (此 时 为 尽 线 型 
拓扑 结构 ) ， 后 来 为 了 节省 成 本 ， 又 开发 了 基于 双 绞 线 标准 以 太 网 规 
范 (此 时 使 用 集线器 作为 集中 连接 设备 ， ， 再 后 来 又 为 了 提高 传输 距 
离 ， 又 诞生 了 光纤 标准 以 太 网 规范 。 


具体 来 说 ， 标 准 以 太 网 规范 中 主要 包括 : 使 用 508 粗 同 轴 电 缆 连 
接 的 10Base5 (对 应 IEEE 802.3 标 准 ) ， 使 用 508 细 同 轴 电 缆 的 10Base2 
(对 应 IEEE 802.3A 标 准 ) ， 使 用 75Q 同 轴 电 缆 的 10Broad36 (对 应 


IEEE 802.3B 标 准 ) ， 使 用 双 绞 线 电 缆 的 10Base-T (对 应 IEEE 802.3I 标 
准 ) 和 使 用 光纤 的 10Base-F (对 应 IEEE 802.3J 标 准 ) 


这 些 规 范 名 称 都 有 其 特殊 含义 的 : 对 于 采用 同 轴 电 缆 作 为 传输 介 
质 的 10Mbps 以 太 网 规范 ， 该 委员 会 给 出 了 他 们 所 采用 的 规范 名 称 格 式 
为 : 


< 数据 传输 速率 (Mbps) > < 信号 传输 模式 > < 最 大 段 长 度 ( 百 米 ) > 


如 10Base-5、10Base-2、10Broad36 中 前 面 的 10 表 示 数 据 传输 速率 
为 10Mbps，Base 表 示 信 和 号 采用 基 市 传输 方式 ， 最 后 面 的 5、2、36 则 分 
别 表 示 这 几 种 标准 中 单 段 介质 的 最 大 长 度 为 500m、200m (实际 上 是 
185m) 和 3.6km。 但 10Base-T 有 些 例外 ， 其 中 的 T 表 示 双 绞 线 (Twisted 
Pairwire) ，10Base-F 中 的 F 表 示 传 输 介质 为 光纤 (Fiber) 


下 面 简单 介绍 这 儿 种 标准 以 太 网 规范 。 
(1) 10Base-5 和 10Base-2 
10Base-5 (或 者 10Base5) 和 10Base-2 (或 者 10Base2) 这 两 个 规范 
都 是 在 使 用 阻抗 为 508 同 轴 电 绕 作 为 传输 介质 的 忌 线 型 拓扑 结构 网 络 


中 ， 均 采用 基带 传输 模式 的 曼彻斯特 编码 (有 关 这 种 编码 的 特点 参见 
第 4 章 相关 内 容 ) 。 两 者 的 主要 区 别 在 于 10Base-5 使 用 粗 同 轴 电 绕 ( 单 


段 电 缆 的 最 大 长 度 为 500m) ，10Base-2 使 用 细 同 轴 电 缆 〈 单 段 电 缆 的 
最 大 长 度 为 180m) 。 


(2) 10Broad36 


10Broad36 是 IEEE 802.3 中 唯一 针对 宽带 系统 〈 如 有 线 广播 、 有 线 
电视 网 络 ) 的 规范 ， 在 采用 阻抗 为 758 同 轴 电 缆 的 总 线 型 网 络 拓扑 结 
构 网 络 中 使 用 。 它 也 采用 基带 传输 模式 的 曼彻斯特 编码 ， 最 大 的 端 到 
端 距 离 为 3.6km。 

(3) 10Base-T 

10Base-T (或 者 写作 10BaseT) 规范 应 用 于 使 用 双 绞 线 作为 传输 介 

质 的 星 型 拓扑 结构 以 太 网 络 中 ， 是 当时 以 太 局 域 网 中 应 用 最 广泛 的 以 


太 网 规范 。 它 也 采用 基 珊 传输 模式 的 曼彻斯特 编码 ， 单 段 电 统 的 最 大 
长 度 为 100m 。 


(4) 10Base-F 


10Base-F (或 者 写作 10BaseF) 规范 使 用 光纤 作为 传输 介质 ， 包 括 
10Base-FL、10Base-FB 和 10Base-FP 三 种 子规 范 ， 均 采用 基 帝 传输 模式 
的 曼彻斯特 编码 ， 但 它们 的 设计 用 途 各 不 相同 。 


口 10Base-FL (或 者 写作 10BaseFL) 子规 范 设计 用 于 与 当时 的 
FOIRL (Fiber OpticInterRepeater Link， 光 纤 中 继 器 间 连 接 ) 协议 协同 


工作 ， 其 目的 就 是 用 来 替换 FOIRL 。 在 与 FOIRL 协 同 工 作 时 单 段 光纤 
长 度 最 大 为 1000m， 纯 10Base-FL 单 段 光 纤长 度 最 大 为 2000m。 显 然 ， 
10Base-FL 是 用 于 光纤 中 继 右 间 的 连接 。 


口 10Base-FB (或 者 10BaseFB) 10Mbps 光 纤 以 太 网 子规 范 设计 用 
于 光纤 骨干 网 (Fiber-Backbone) 中 同步 信 令 的 传输 ， 用 于 将 其 他 网 段 
通过 中 继 器 连接 到 本 地 网 络 〈 不 是 用 于 用 户 连 接 的 ， 用 户 光 纤 连 接 采 
用 的 是 10Base-FP 子 规范 ) ， 单 段 光纤 长 度 最 大 为 2000m。 显 然 ， 
10Base-FB 是 用 于 集线器 ， 或 交换 机 与 光纤 中 继 右 间 的 连接 。 


口 10Base-FP (或 者 写作 10BaseFP) 是 一 种 用 于 连接 无 源 光 纤 
(Fiber-Passive) 器 件 (这 里 的 “无 源 ” 是 指 不 需要 接 外 部 电源 就 可 直接 
工作 ) 的 以 太 网 子规 范 ， 可 以 无 需 中 继 器 即 可 连接 大 量 用 户 (通过 集 
线 器 或 交换 机 ) 组 成 星 形 拓扑 结构 网 络 ， 单 段 光纤 长 度 最 大 为 500m 。 
显然 ，10Base-FP 是 用 于 用 户 与 集 线 侣 ， 或 交换 机 间 的 连接 。 


6.5.2 标准 以 太 网 物理 层 结构 


因为 在 IEEE 802.3 以 太 网 中 ，MAC 子 层 是 直接 与 物理 层 直 接连 接 
的 ， 关 系 非 常 密切 ， 所 以 把 以 太 网 中 的 物理 层 结构 放 在 本 章 介绍 。 


标准 以 太 网 接口 的 物理 层 和 数据 链 路 层 结构 (注意 ， 这 里 是 基于 
逻辑 功能 上 的 划分 ， 不 是 基于 物理 结构 上 的 划分 ) 如 图 6-28 所 示 。 从 
图 中 可 以 看 出 ， 标 准 以 太 网 的 物理 层 包含 了 以 下 三 个 部 分 :1 MAU、 
AUI 和 PLS。 下 面 分 别 予 以 介绍 。 


计算 机 系统 总 线 


线 接 [ 有 
-本 


MAC 子 层 


PMA 子 层 
MDI 了 局 个 

玉 传输 介质 
6-28 ”10Mbps 以 太 网 物理 层 和 数据 链 路 层 结构 


1 人 大 过 区 早 元 


MAU (Medium Attachment Unit， 介 质 连接 单元 ) 是 网 络 接口 用 
来 直接 与 传输 介质 《如 同 轴 电 缆 、 双 绞 线 ， 光 纤 等 ) 连接 的 那 部 分 结 
构 ， 发 挥 作用 的 是 里 面 的 收发 器 (transceiver) 芯片 。 在 该 部 分 中 又 包 
括 了 PMA (Physical Medium Attachment， 物 理 介 质 连接 ) 和 介质 相关 
接口 (Medium Dependant Interface，MDI) 两 个 子 层 的 功能 ， 在 网 络 
接口 和 传输 介质 之 间 提 供 机 械 连 接 和 电气 特性 接口 。 


MDI 子 层 是 标准 以 太 网 络 接口 物理 层 中 的 最 低层 ， 直 接 负 责 处 理 
网 络 接口 与 传输 介质 的 连接 ， 其 实 就 是 网 络 接口 连接 器 。 它 定义 了 电 
缆 、 连 接 电缆 的 连接 器 ， 以 及 电缆 两 端的 终端 负载 的 特性 。 因 为 标准 
以 太 网 可 以 有 多 种 不 同 传输 介质 类 型 ， 所 以 也 就 对 应 有 多 种 MDI 连 接 
器 ， 这 也 就 是 MDI 中 “相关 ”的 含义 。 如 粗 同 轴 电缆 的 MDI 称 为 插入 式 
分 接头 (其实 又 称 AUI 接 口 ， 如 图 6-29 所 示 ) ， 细 同 轴 电 缆 的 MDI 是 
BNC 连 接 器 (如 图 6-30 所 示 ) ， 双 绞 线 以 太 网 的 MDI 称 为 RJ 一 45 连 接 
器 (如 图 6-31 所 示 ) ， 光 纤 以 太 网 的 MDI 可 以 是 ST 或 者 SC 连接 器 等 

(分 别 如 图 6-32、 图 6-33 所 示 ) 。 


6-29 ” 粗 同 轴 电 绕 AUI 连 接 器 


6-30 细 同 轴 电 缆 BNC 连 接 器 


6-31 双 绞 线 RJ-45 连 接 器 


6-32 ”ST 光纤 连接 器 


6-33 ”SC 光纤 连接 器 


PMA 于 层 癌 PLS 于 层 提 供 服 务 ， 人 负责 处 理 与 物理 介质 连接 方面 的 
功能 (在 收发 器 中 实现 ) ， 如 串 / 并 行 传输 的 转换 、 检 测 冲 突 、 超 时 控 
制 (jabber control) ， 以 及 收发 比特 流 。 其 中 的 超时 控制 是 指 当 检测 
到 某 个 站 点 发 送 的 数据 超过 设 定 的 最 长 传输 时 间 (在 芯片 中 有 专门 负 


责 超时 检测 的 引 脚 ) 时 ， 即 认为 该 站 点 出 了 故障 ， 接 着 就 会 自动 禁止 
该 站 癌 总 线 发 送 数 据 。 

2. 连 接 单 元 接口 

AUI (Attachment Unit Interface， 连 接 单 元 接口 ) 相当 于 网 络 接口 
收发 器 上 的 电缆 。 它 定义 了 将 MAU 与 PLS 子 层 相连 的 电缆 的 机 械 和 电 
气 特性 ， 同 时 还 定义 了 通过 这 个 电 统 所 交换 的 信号 的 特性 。AUI 上 的 
信号 有 4 种 :发送 和 接收 的 曼彻斯特 编码 、 冲 突 信 号 和 电源 信号 。 


注意 ”如 有 果 PLS 子 层 与 PMA 了 于 层 处 于 同一 个 DTE 设 备 中 ， 就 不 需 
要 AUI 和 MAU 了 ， 但 DTE 与 同 轴 电 比 的 MDI 子 层 还 十 需 要 的 。 


3. 物 理 层 信号 子 层 


PLS (Physical Layer Signaling， 物 理 层 信号 ) 子 层 为 MAC 子 层 服 
务 ， 是 在 网 卡 中 实现 的 (PMA 子 层 和 MDI 子 层 是 在 收发 器 中 实现 
的 ) 。 如 果 PLS 子 层 与 PMA 子 层 不 处 在 同一 个 设备 中 ， 则 它 通 过 AUI 
与 MAU 连 接 。 从 其 名 称 可 以 看 出 ，PLS 子 层 的 主要 功能 是 对 物理 层 信 
号 的 处 理 ， 具 体 包括 以 下 两 个 方面 : 


口 编码 /解码 : 发 送 时 将 MAC 子 层 来 的 串 行 数 据 编码 为 曼彻斯特 纺 
码 ， 并 通过 收发 如 电 统 发 送 给 收发 右 ， 接 收 时 ， 接 收 AUI 发 送 来 的 曼 
彻 斯 竺 编码 信号 ， 并 进行 解码 ， 然 后 以 串 行 方式 发 送 给 MAC 子 层 。 


口 载波 侦 听 : 确定 介质 是 否 空闲 ， 然 后 把 侦 听 到 的 载波 侦 听 信和 号 
发 送 给 MAC 子 层 。 


6.6 ”快速 以 太 网 规范 及 体系 结构 


100Mbps 的 快速 以 太 网 (Fast Ethernet) 技术 是 由 10Mbps 标 准 以 太 
网 发 展 而 来 的 ， 主 要 解决 网 络 带宽 在 局 域 网 络 应 用 中 的 瓶颈 问题 。 其 
协议 标准 为 1995 年 颁布 的 IEEE 802.3u (100Base) ， 可 支持 100Mbps 的 
数据 传输 速率 。 


IEEE 802.3u 在 MAC 子 层 仍 采用 了 在 IEEE 802.3 标 准 以 太 网 中 的 
CSMA/CD 作 为 介质 访问 控制 协议 ， 并 保留 了 标准 以 太 网 的 MAC 和 LELC 
帧 格式 。 但 是 ， 为 了 实现 100 Mbps 的 传输 速率 ， 在 物理 层 做 了 一 些 重 
要 的 改进 。 例 如 ， 在 编码 上 采用 了 效率 更 高 的 编码 方式 一 一 4B/5B 编 码 

(在 10Mbps 以 太 网 中 采用 的 是 曼彻斯特 编码 方式 ， 但 其 编码 效率 比较 
低 ， 有 效 信号 只 占 1/2 码 字 ) 。 


6.6.1 快速 以 太 网 规 苑 


IEEE 802.3u 快 速 以 太 网 标准 中 定义 了 以 下 三 种 不 同 的 快速 以 太 网 


规范 : 


口 100Base-TX: 采用 两 对 (4 根 ) 芯 线 的 5 类 (包括 超 5 类 ) 非 屏 向 
双 绞 线 或 者 屏蔽 双 绞 线 作为 传输 介质 


口 100Base-T4: 采用 四 对 (全 部 的 8 根 ) 世 线 普通 3、4、5 类 (包括 
超 5 类 ) 双 绞 线 作为 传输 介质 


口 100Base-FX: 采用 光纤 作为 传输 介质 


IEEE 802.3u 标 识 符 包 括 三 块 信息 : 其 一 ，100 表 示 传 输 速度 
100Mbps; 其 二 ，Base 表 示 信 和 号 仍 采用 基带 传输 方式 ， 甚 三， 是 关于 网 
络 段 类 型 的 曾 述 ，T4 表 示 要 用 四 对 双 绞 线 ， TX 表示 要 用 两 对 双 绞 线 ， 
FX 表示 要 用 两 条 光纤 。 下 面 是 这 三 种 快速 以 太 网 标准 的 介绍 。 


1.100Base-TX 


100Base-TX 快 速 以 太 网 规范 是 采用 两 对 心 线 的 双 绞 线 电 比 (可 以 
是 5 类 或 超 5 类 屏蔽 或 非 屏 蔽 双 绥 线 ， 但 目前 普遍 采用 的 是 成 本 更 低 ， 
更 易 用 布线 的 非 屏 项 双 绞 线 ) 的 ， 其 中 一 对 用 于 发 送 数据 ， 另 一 对 用 
于 接收 数据 。 该 标准 直接 用 于 取代 标准 以 太 网 中 的 10Base-T 和 10Base-2 


规范 。 


100Base-TX 规 范 中 的 MDI (介质 相关 接口 ) 连接 器 有 两 种 对 于 
非 屏 菩 双 纹 线 (UTP) ，MDI 子 层 连 接 吉 是 8 个 引 脚 的 RJ 一 45 连 接 器 ; 
对 屏蔽 双 绞 线 (STP) ，MDI 子 层 连 接 器 必须 是 IBM 的 STP 连 接 器 。 


如 果 使 用 的 是 非 屏蔽 双 绞 线 ，100Base-TX 规 范 中 只 使 用 了 四 对 芯 
线 中 的 两 对 ， 男 外 两 对 心 线 没有 使 用 。 根 据 EIA/TIA-568B 布 线 标准 ， 


直通 双 绞 网 线 (两 端 同 时 用 TIA/EIA-568A， 或 者 TIA/EIA-568B 标 准 ， 
用 于 不 同 设备 的 连接 ， 如 PC 机 到 集线器 、 交 换 机 的 连接 ， 交 换 机 到 路 
由 器 的 连接 等 ) RJ 一 45 连 接 器 的 8 个 引 脚 与 双 绞 线 8 条 芯 线 的 连接 如 表 


6-3 所 示 。 


表 6-3 100Base-TX 直通 UTP 网 线 水 晶 头 引 脚 、 信 号 功能 与 双 绞 芯 线 的 连接 分 配 表 


信号 功能 


20 一 1 Cn III 


世 线 颜色 
枪 白 色 
橙色 
绿 白色 


100Base-TX 标 准 也 支持 特征 阻抗 为 1508 的 5 类 屏蔽 双 绞 线 。 屏 殴 双 
绞 线 电缆 使 用 D 型 连接 器 。 直 通 STP 网 线 DB-9 连 接 器 上 引 脚 与 双 绞 芯 线 


表 6-4 100Base-TX 的 STP MDI 连接 器 引 脚 与 双 绞 芯 线 的 连接 分 配 表 


的 连接 如 表 6-4 所 示 。 
引 脚 号 
10 
1 
4 
- 
8 
9 


信号 功能 
公共 地 
接收 十 
保留 
保留 
保留 
发 送 十 
接收 一 
保留 
保留 


发 送 


心 线 颜 色 
电费 外 这 


橙色 


当 要 使 用 交叉 电缆 时 (如 同类 设备 普通 端口 上 的 级 联 ) ， 按 照 表 6- 
5 所 示 的 跳 线 规则 进行 交叉 网 线 〈 一 端 用 TIA/EIA-568A 标 准 ， 另 一 端 用 
TIA/EIA-568B 标 准 ， 用 于 同 种 设备 的 连接 ， 如 PC 机 到 PC 机 的 连接 ， 交 
换 机 普通 端口 间 的 级 连 ，PC 机 到 路 由 器 的 连接 ， 路 由 需 与 路 由 器 间 的 
连接 等 ) 制作。 但 是 目前 的 以 太 网 端口 基本 上 都 支持 电 绕 跳 线 自 动 翻 
转 功 能 ， 任 何 情况 下 都 既 可 以 使 用 直通 网 线 ， 又 可 以 使 用 交叉 网 线 ， 
所 以 目前 一 般 只 做 直通 网 线 即 可 。 

表 6-5 100Base-TX 交叉 网 线 引 脚 分 配对 比 表 
5 类 UTP 电缆 世 线 颜色 5 类 STP 电缆 芯 线 颜色 


- 端 颜色 另 一 端 颜色 - 端 颜色 另 一 端 颜色 


红色 


引 脚 号 


黑色 
公共 地 


从 表 6-5 可 以 看 出 ， 在 使 用 非 屏 蔽 双 绞 线 (UTP) 制作 交换 网 线 时 
两 端的 心 线 呈 以 下 关系 : 


口 一 端的 1 号 引 脚 所 对 应 的 必 线 与 太一 问 的 3 号 引 脚 对 应 的 心 线 一 
样 ， 即 1 号 引 脚 与 3 号 引 脚 对 调 ; 


口 一 端的 2 号 引 脚 所 对 应 的 已 线 与 男 一 问 的 6 号 引 脚 对 应 的 心 线 一 
样 ， 即 2 号 引 脚 与 6 号 引 脚 对 调 。 


在 使 用 屏蔽 双 绞 线 (STP) 制作 交换 网 线 时 两 端的 已 线 呈 以 下 关 
系 : 


口 一 端的 1 号 引 脚 所 对 应 的 必 线 与 太一 问 的 5 号 引 脚 对 应 的 心 线 一 
样 ， 即 1 号 引 脚 与 5 号 引 脚 对 调 ; 


一 疾 的 6 号 引 脚 所 对 应 的 忌 线 与 男 一 并 的 9 号 引 脚 对 应 的 忌 线 一 
样 ， 即 6 号 引 脚 与 9 号 引 脚 对 调 。 


2.100Base- 工 4 


100Base-T4 是 用 来 癌 下 兼容 那些 已 经 安 冯 了 3 类 或 4 类 非 屏 珊 双 绥 
线 电 缆 《当然 也 可 以 使 用 5 类 或 超 5 类 双 绞 线 ) 的 快速 以 太 网 规范 ， 但 
它 要 求 同 时 使 用 双 绞 线 电缆 中 的 全 部 四 对 〈8 根 ) 必 线 ， 这 也 就 是 T4 的 
由 洒 


100Base-T4 规 范 采 用 半 双 工交 换 方 式 ， 在 它 的 四 对 必 线 中 ， 三 对 
用 于 一 起 发 送 数据 ， 第 四 对 用 于 冲突 检测 〈 其 目的 殉 是 为 了 实现 在 3 类 
或 4 类 非 屏蔽 双 绞 线 电 绵 中 实现 100Mbps 的 传输 速率 ) 。 其 RJ 一 45 连 接 
右 引 脚 与 双 绞 线 改线 的 连接 分 配 如 表 6-6 所 示 。 


表 6-6 100Base-T4 水 晶 头 引 脚 、 信 号 功能 与 双 绞 芯 线 的 连接 分 配 表 


3 ERE 
外 和 多 
; 名 
1 Ee 
5 ET 
训 
7 也 和 多 
; 这 


表 6-7 所 示 的 是 100Base-T4 规 范 中 的 交叉 双 绞 网 线 RJ-45 连 接 器 引 脚 
与 双 绞 芯 线 的 连接 分 配 表 。 


表 6-7 100Base-T4 交叉 双 绞 网 线 RJ-45 连接 器 引 脚 与 双 绞 芯 线 的 连接 分 配 表 


引 脚 号 另 一 端 世 线 颜色 
人 6 色 | 绿 白色 
; 入 白 色 
4 棕 白 色 
5 蓝 白 色 棕色 
7 监 色 
8 蓝 白 色 


从 表 6-7 中 可 以 看 出 ， 在 制作 100Base-T4 规 范 交 双双 绞 线 时 两 端的 
心 线 呈 以 下 关系 : 


口 一 问 的 1 号 引 脚 所 对 应 的 心 线 与 男 一 问 的 3 号 引 脚 对 应 的 已 线 一 
样 ， 即 1 号 引 脚 与 3 号 引 脚 对 调 ; 


口 一 问 的 2 号 引 脚 所 对 应 的 耿 线 与 另 一 端的 6 号 引 脚 对 应 的 心 线 一 
样 ， 即 2 号 引 脚 与 6 号 引 脚 对 调 ; 


口 一 端的 4 号 引 脚 所 对 应 的 已 线 与 男 一 问 的 7 号 引 脚 对 应 的 心 线 一 
样 ， 即 4 号 引 脚 与 7 号 引 脚 对 调 ; 


口 一 问 的 5 号 引 脚 所 对 应 的 耿 线 与 另 一 端的 8 号 引 脚 对 应 的 心 线 一 
样 ， 即 5 号 引 脚 与 8 号 引 脚 对 调 。 


在 100Base-T4 规 范 中 ， 原 来 的 1、3 和 2、6 这 两 对 双 绞 芯 线 与 
100Base-TX 规 范 一 样 ， 仍 只 能 采用 半 双 工 传输 ， 但 另外 两 对 双 绥 心 线 
可 以 全 双 工 传输 ， 如 图 6-34 所 示 。 


-| > A > 冲突 检测 
第 一 对 双 绞 线 
第 综 线 
' ' 
Ia 


集 线 希 


图 6-34 100Base-T4 规 范 中 的 双 统 心 线 使 用 情况 


当 工 作 站 传送 数据 给 集线器 或 交换 机 时 ， 第 1、3、4 对 双 绞 线 用 来 
传送 数据 ， 而 第 2 对 双 绞 线 则 用 来 检测 冲突 ;而 当 集线器 或 交换 机 传送 
数据 给 工作 站 时 ， 第 2、3、4 对 双 绞 线 用 来 传送 数据 ， 而 第 1 对 双 绞 线 
则 用 来 侦 测 冲突 。 也 就 是 说 ， 每 一 个 方向 的 传送 都 同时 使 用 了 三 对 双 
绞 线 来 传送 数据 。 这 样 一 来 ， 对 于 100Mbps 的 传送 速率 来 说 ， 每 一 对 双 
绞 线 的 传送 速率 只 有 33.33 Mbps， 更 加 容易 实现 。 另 外 ，100Base-T4 规 
范 所 采用 的 是 8B/6I 编 码 方法 (不 再 是 其 他 快速 以 太 网 规范 所 使 用 的 
4B/5B 编 码 方式 ) ， 至 于 这 些 编码 方式 在 此 不 做 介绍 ， 大 家 可 以 查看 其 
他 相关 资料 。 


3.100Base-FX 


100Base-FX 快 速 以 太 网 规范 采用 的 是 两 条 光纤 ( 单 工 模式 ) ， 一 
条 用 于 发 送 数据 ， 一 条 用 于 接收 数据 〈 现 在 新 型 的 光纤 连接 方式 是 仅 
需 一 条 光纤 ， 可 同时 用 于 发 送 和 接收 数据 ， 它 采用 的 是 波 分 复 用 方 
式 ) 。 当 工作 站 的 光纤 网 卡 以 全 双 工 模式 运行 时 能 超过 2km 。100Base- 
FX 规范 中 可 使 用 的 光纤 有 以 下 两 类 (有 关 光 纤 分 类 的 详细 知识 参见 第 4 


章 ) 


= 
口 多 模 光 纤 : 这 种 光纤 的 纤 径 为 62.5/125pm， 采 用 基于 LED (发 光 


二 极 管 ) 的 收发 絮 将 波长 为 820nm 的 光 信号 发 送 到 光纤 上 。 当 连 在 两 个 
设置 为 全 双 工 模式 的 交换 机 端口 之 间 时 ， 文 持 的 最 大 距离 为 2km 。 


口 单 模 光 纤 : 这 种 光纤 的 纤 径 为 90125hm， 采 用 基于 激光 的 收发 器 
将 波长 为 1300nm 的 光 信号 发 送 到 光纤 上 。 单 模 光纤 率 损耗 小 ， 较 之 多 
模 光 纤 能 使 光 信 号 传输 到 更 远 的 距离 。 


6.6.2 ”快速 以 太 网 物理 技 结 构 


快速 以 太 网 与 前 面 介绍 的 标准 以 太 网 在 物理 层 结构 上 存在 比较 大 
的 区 别 ， 具 体 对 比如 图 6-35 所 示 。 下 面 仍 以 由 低 到 高 的 顺序 介绍 这 些 逻 


辑 组 成 部 分 。 


计算 机 系统 总 线 


总 线 接口 
LT 和 层 
MAC 子 层 
PLS 子 层 


| PMA 了 层 _ 


失传 输 介质 
快速 以 太 网 物理 层 结构 


玉 传输 介质 


十 兆 以 太 网 物理 层 结构 
图 “6-35 标准 以 太 网 与 快速 以 太 网 的 体系 结构 比较 


(1) 介质 相关 接口 子 层 


在 标准 以 太 网 物理 层 结构 中 的 最 低层 也 是 介质 相关 接口 (Medium 
Dependent Interface，MDI) 子 层 ， 而 且 功 能 也 是 一 样 的 ， 规 定 PMD 子 
层 和 传输 介质 之 间 的 连接 器 类 型 ， 比 如 100Base-TX 的 RJ 一 45 连 接 器 ， 


100Base-FX 的 SC、ST 连 接 器 等 。 


(2) 物理 介质 相关 子 层 


物理 介质 相关 (Physical Media Dependent，PMD) 子 层 是 快速 以 
太 网 物理 层 结构 中 新 增加 的 一 层 ， 位 于 收发 器 上 。 它 与 物理 介质 直接 
相连 的 是 信号 收发 器 和 信和 号 检测 模块 ， 主 要 提供 信号 的 收发 、 检 测 和 
编 /解码 等 功能 。 发 送信 号 时 ， 要 将 来 自 PMA 子 层 的 信号 经 过 适当 的 编 
码 转换 成 适合 特定 传输 介质 的 信号 ， 并 提供 发 送信 号 驱动 ， 接 收 信号 
时 ，PMD 子 层 经 过 相应 的 解码 处 理 后 发 送 给 PMA 子 层 。 


(3) 物理 介质 连接 子 层 


物理 介质 连接 (Physical Medium Attachment，PMA) 子 层 完成 链 
路 监测 、 载 波 检测 、NRZI (〈 非 归 零 翻转 ) 编 / 解 码 、 发 送 时 钟 合 成 和 接 
收 时 钟 恢复 的 功能 。 


(4) 物理 编码 子 层 


物理 编码 子 层 (Physical Coding Sublayer，PCS) 的 主要 功能 是 
4B/5B 编 /解码 (而 不 是 标准 以 太 网 中 的 曼彻斯特 编码 ， 当 然 在 100Base- 
T4 规 范 中 使 用 的 是 8B/6T 编 /解码 方式 ) 、 人 碰撞 检测 和 并 捉 转 换 。 


(5) 介质 无 关 接口 


MII (Medium Independent Interface， 介 质 无 关 接 口 ) 逻辑 上 与 
10Mbps 以 太 网 的 AUI 接 口 对 应 ， 可 以 使 MAC 子 层 与 传输 介质 无 关 。 


MII 在 发 送 和 接收 数据 时 ， 由 原来 标准 以 太 网 AUI 的 一 位 位 的 串 行 传输 
改变 为 半 字 节 (4 位 ) 的 并 行 传输 ， 这 样 发 送 和 接收 时 钟 频率 只 需 整个 
数据 传输 速率 的 /4， 即 25MHz， 更 容易 实现 ， 也 更 稳定 。 


(6) 协调 子 层 


协调 子 层 (Reconciliation Sublayer，RS) 替换 原来 标准 以 太 网 PLS 
子 层 。PLS 子 层 的 功能 是 对 物理 层 信号 进行 编 /解码 和 载波 检测 ， 而 快 
速 以 太 网 的 RS 是 将 MAC 子 层 的 业务 定义 映 喘 成 MII 授 口 的 信号。 


6.7 和 干粮 以 太 网 规范 及 体系 结构 


1996 年 3 月 IEEE 802 委 员 会 成 立 了 IEEE 802.3z 工 作 组 ， 专 门 负 责 
兆 以 太 网 及 其 标准 ， 并 于 1998 年 6 月 正式 公布 关于 于 兆 以 太 网 的 标准 ， 
后 面 的 IEEE 802.3ab 标 准 下 的 1000Base-T 规 范 是 在 1999 年 6 月 正式 批准 
发 布 的 ， 其 数据 传输 率 均 达到 了 1000Mbps， 即 1Gbps， 因 此 又 称 吉 比 
特 以 太 网 。 


千 兆 以 太 网 基本 保留 了 原 有 以 太 网 的 帧 结构 ， 同 时 也 支持 
CSMA/CD 介 质 访问 控制 技术 ， 所 以 向 下 与 标准 以 太 网 和 快速 以 太 网 完 
全 兼容 ， 原 有 的 10Mbps 以 太 网 或 快速 以 太 网 可 以 方便 地 升级 到 千 兆 以 
太 网 。 


6.7.1 于 兆 以 太 网 规 艺 


最 早 在 1998 和 1999 年 发 布 的 IEEE 802.3z 和 IEEE 802.3ab 标 准 中 就 包 
括 了 : 1000Base-LX、1000Base-SX、1000Base-CX 和 1000Base-T (前 三 
种 统称 为 1000Base-X 子 系列 ) 四 个 ， 如 图 6-36 所 示 。 其 中 前 三 个 是 由 
IEEE 802.3z 标 准 规定 的 ， 而 1000 Base-T 规 范 则 是 由 IEEE 802.3ab 标 准 规 
定 的 ， 是 后 面 专 门 开 发 的 。 这 四 个 千 兆 以 太 网 规范 支持 不 同类 型 的 光 
纤 和 双 绞 线 电 缆 。 


编码 /解码 器 
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图 6-36 千 兆 以 太 网 体系 结构 


除了 以 上 四 种 以 标准 形式 发 布 的 IEEE 千 兆 以 太 网 规范 外 ， 在 工业 
应 用 中 ， 还 有 些 并 没有 正式 以 标准 形式 对 外 发 布 ， 但 却 实 实 在 在 有 广 
泛 应 用 的 千 上 兆 以 太 网 规范 ， 如 1000Base-LH、1000Base-ZX、1000Base- 


LX10、1000Base-BX10、1000Base-TX 这 五 种 规范 。 


这 样 一 来 ， 在 和 干粮 以 太 网 系列 中 加 起 来 一 共 束 有 九 种 规范 了 。 在 
这 九 种 千 兆 以 太 网 规范 中 ， 根 据 所 采用 的 传输 介质 类 型 ， 总 体 上 有 十 分 
两 大 类 的 : 基于 光纤 的 和 基于 双 绞 线 的 。 下 面 分 别 予 以 介绍 。 


1. 基 于 光纤 的 千 兆 以 太 网 规范 


千 兆 速率 已 相当 高 ， 从 总 体 性 能 上 来 说 ， 最 适宜 的 介质 就 是 光纤 
了 ， 所 以 自 和 干 兆 以 太 网 以 后 ， 包 括 后 面 的 万 兆 ， 甚 至 现在 正在 人 研究 之 
中 的 10 万 兆 以 太 网 规范 中 ， 绝 大 多 数 是 基于 光纤 这 种 传输 介质 开发 
的 。 在 以 上 九 种 千 兆 以 太 网 规范 中 ， 就 有 六 种 是 基于 光纤 的 。 它 们 分 
别 是 已 以 标准 形式 发 布 的 1000Base-LX 和 1000Base-SX， 不 是 以 标准 形 
式 发 布 的 1000Base-LH、1000Base-ZX、1000Base-LX10 和 1000Base- 
BX10 。 


(1) 1000Base-LX 


这 是 一 种 通过 光纤 进行 通信 的 IEEE 千 兆 以 太 网 规范 ， 既 可 以 使 用 
单 模 光 纤 (SMF) ， 也 可 以 使 用 多 模 光 纤 (MMF) 。1000Base-LX 使 
用 长 波长 激光 ， 波 长 为 1310nm。1000Base-LX 规 范 所 使 用 的 光纤 主要 
有 线 径 62.5nm 的 多 模 光 纤 、50nm 的 多 模 光纤 和 9nm 的 单 模 光纤 。 其 中 
使 用 多 模 光 纤 的 最 大 传输 距离 为 550m， 使 用 单 模 光纤 的 最 大 传输 距离 
为 5km。1000Base-LX 规 范 采 用 8B/10B 数 据 编码 方法 ， 主 要 适用 于 校园 
网 或 城 域 网 的 主干 网 。 


(2) 1000Base-SX 


这 也 是 一 种 通过 光纤 进行 通信 的 IEEE 千 兆 以 太 网 规范 ， 适 用 于 线 
径 为 50nm 和 62.5nm 的 短波 (波长 为 850nm) 多 模 光 纤 (MMF) 。 其 中 


使 用 62.5nm 多 模 光 纤 的 最 大 传输 距离 为 275m， 使 用 50nm 多 模 光 纤 的 最 
大 传输 距离 为 550m。1000Base-SX 规 范 也 采用 8B/10B 数 据 编码 方法 ， 
适用 于 大 楼 网 络 系统 的 主干 通路 。 


(3) 1000Base-LH 


这 是 一 个 非 标准 的 千 兆 以 太 了 网 规范 ， 采 用 的 是 波长 为 1300nm 或 者 
1310nm 的 单 模 或 者 多 模 长 波光 纤 。 它 类 似 于 1000Base-LX 规 范 ， 但 在 
单 模 优质 光纤 中 的 最 长 有 效 传输 距离 可 达 10km， 并 且 可 以 与 1000Base- 
LX 网 络 保持 兼容 。 


(4) 1000Base-ZX 


这 也 是 一 个 非 标准 的 干 兆 以 太 网 规范 ， 采 用 的 是 波长 为 1550nm 的 
单 模 超 长 波光 纤 ， 最 长 有 效 传输 距离 可 达 70km 。 


(5) 1000Base-LX10 


这 也 是 一 个 非 标 准 的 千 兆 以 太 网 规范 ， 采 用 的 是 波长 为 1310nm 的 
单 模 长 站 光纤， 最 长 有 效 传输 距离 可 达 10km 。 


(6) 1000Base-BX10 


这 也 是 一 个 非 标准 的 干 兆 以 太 网 规范 ， 其 两 根 光 纤 所 采用 的 传输 
介质 类 型 是 不 同 的 : 下 行 方向 (从 网 络 中 心 到 网 络 边缘 ) 采用 的 是 波 


长 为 1490nmb 的 单 模 超 长 波 区 纤 ， 而 上 行 方 癌 则 是 采用 1310nm 的 单 梗 长 
六 光纤 ， 最 长 有 效 距离 为 10km 。 


2. 基 于 双 绥 线 的 千 兆 以 太 网 规范 


采用 双 绞 线 作为 传输 介质 的 干粮 以 太 网 规范 有 以 下 三 个 : 


(1) 1000Base-CX 


这 是 一 种 采用 1508 平 衡 屏 蔽 双 绞 线 (STP) 作为 传输 介质 (连接 
器 为 DB-9) 的 千 兆 以 太 网 规范 ， 传 输 距 离 最 长 仅 为 22m， 数 据 编码 方 
法 为 8B/10B， 适 用 于 数据 中 心 设备 间 (如 交换 机 之 间 的 连接 ， 尤 其 适 
用 于 主干 交换 机 和 主 服务 器 之 间 的 短 距离 连接 ) ， 或 者 堆 谷 设备 间 的 
短 距离 互 连 ， 但 不 适用 于 数据 中 心 与 配 线 架 的 连接 。 


(2) 1000Base-T 


这 是 一 种 可 以 采用 5 类 、 超 5 类 、6 类 或 者 7 类 双 绞 线 的 全 部 四 对 忌 
线 作 为 传输 介质 的 千 兆 以 太 网 规范 ， 对 应 标准 为 IEEE 802.3ab (与 其 他 
王 兆 以 太 网 标准 不 同 ) 。 它 的 最 大 传输 距离 为 100m。 在 全 部 的 四 对 双 
绞 心 线 中 ， 每 对 都 可 以 同时 进行 全 双 工 数据 收发 ， 所 以 即使 是 相同 设 
备 间 的 连接 ， 也 无 须 制 作 交 叉 线 ， 两 端 都 用 相同 的 布线 标准 即 可 。 这 
征 目 前 在 企业 局 域 网 中 最 般 用 的 一 种 千 兆 以 太 网 标准 。 


(3) 1000Base-TX 


在 千 兆 以 太 网 标准 中 还 有 一 种 浓 用 的 标准 ， 那 就 是 1000Base-TX， 
但 它 不 是 由 IEEE 制 作 的 ， 而 是 由 TIA/EIA 于 1995 年 发 布 的 ， 对 应 的 标准 
号 为 TIA/EIA-854。 


尽管 1000Base-TX 也 是 基于 四 对 双 绞 线 ， 但 却 采 用 快速 以 太 网 中 
100Base-TX 标 准 类 似 的 传输 机 制 ， 是 以 两 对 线 发 送 ， 两 对 线 接收 (类 
似 于 100Base-TX 的 一 对 线 发 送 ， 一 对 线 接 收 ) 。 由 于 每 对 线 缆 本 身 不 
同时 进行 双向 的 传输 ， 线 缆 之 间 的 串扰 惑 大 大 降低 ， 同 时 其 编码 方式 
也 是 8B/10B。 这 种 技术 对 网 络 的 接口 要 求 比较 低 ， 不 需要 非常 复杂 的 
电路 设计 ， 降 低 了 网 络 接 口 的 成 本 。 但 由 于 使 用 线 绕 的 效率 降低 了 

(两 对 线 收 ， 两 对 线 发 ) ， 要 达到 1000Mbps 的 传输 速率 ， 要 求 带 宽 就 
超过 100MHz， 也 就 是 说 在 5 类 和 超 5 类 的 系统 中 不 能 文 持 该 类 型 的 网 
络 。 一 定 需要 6 类 或 者 7 类 双 绞 线 系统 的 支持 。 


以 上 九 种 千 兆 以 太 网 规范 的 比较 如 表 6-8 所 示 ， 从 中 可 以 看 出 各 规 
苑 的 主要 优势 和 特性 。 


表 6-8 九 种 千 兆 以 太 网 规范 比较 


ET 人 
1000Base-CX 150Q 双 绞 线 25m 
1000Base-LX 波长 为 1310nm 的 单 模 或 者 多 模 光 纤 Skm 
1000Base-SX 波长 为 850nm 的 多 模 光 纤 275~550m 
1000Base-LH 波长 为 1310nm 的 单 模 或 者 多 模 光 纤 10km 


1000Base-ZX 波长 为 1550nm 的 单 模 光 纤 70km 
1000Base-LX10 波长 为 1300nm 或 1310nm 的 单 模 光 纤 或 多 模 光 纤 10km 
1000Base-BX10 下 行为 波长 为 1490nm 的 单 模 光 纤 ， 上 行为 波长 为 1310nm 的 单 模 光 纤 10km 
1000Base-T 5 类 、 超 5 类、6 类 或 者 7 类 双 绞 线 100m 
1000Base-TX 6 类 或 者 7 类 双 绞 线 100m 


6.7.2 ”1000Base-T 以 太 网 技术 


在 以 上 九 种 千 兆 以 太 网 规范 中 ， 人 性价比 最 高 的 就 是 1000Base-T 这 
种 采用 普通 5 类 以 上 双 绞 线 的 千 兆 以 太 网 规范 。 尽 管 在 双 绞 线 和 干 兆 以 太 
网 规范 中 还 有 一 种 1000Base-TX 的 规范 ， 但 是 它 只 能 使 用 6 类 以 上 的 双 
绞 线 ， 网 络 建设 成 本 明显 要 高 于 1000Base-T 规 范 。 所 以 在 此 专门 介绍 
一 下 这 种 应 用 最 广 的 1000Base-T 千 兆 以 太 网 规范 。 


1000Base-T 是 专门 为 在 5 类 双 绞 线 上 进行 千 兆 速率 数据 传输 而 设计 
的 。 它 采用 了 双 绞 线 的 全 部 四 对 芯 线 ， 并 且 是 全 双 工 传输 的 ， 也 就 是 
每 对 双 绞 线 都 可 以 同时 进行 数据 的 发 送 和 接收 ， 这 样 一 来 1000Mbps 的 
传送 速率 可 以 等 效 地 看 作 在 四 对 双 绞 线 上 ， 每 对 的 传送 速率 为 250Mbps 
(1000Mbps/4=250Mbps) 。 


因为 1000Base-T 只 文 持 全 双 工 传输 ， 所 以 与 1000Base-T 千 兆 以 太 网 
端口 直接 相连 的 端口 也 必须 是 支持 全 双 工 的 以 太 网 端口 (最 佳 情况 则 
是 同时 为 1000Base-T 干 兆 以 太 网 端口 ) ， 而 不 能 是 半 双 工 的 ， 否 则 一 
方面 性 能 会 严重 下 降 ， 达 不 到 千 兆 的 效果 ， 另 一 方面 还 会 有 严重 的 丢 
包 现 象 。 相 比 之 下 ， 男 一 个 干 兆 以太 网 规范 一 一 1000Base-TX 尽 管 也 是 
采用 了 全 部 的 四 对 双 绞 芯 线 ， 但 是 它 同 一 时 间 是 两 对 (4 根 ) 忌 线 用 于 
发 送 ， 两 对 (4 根 ) 必 线 用 于 接收 ， 属 于 半 双 工 模式 ， 类 似 于 快速 以 太 


网 中 的 100Base-TX 规 范 ， 只 不 过 100Base-TX 规 范 中 ， 同 一 时 间 发 送 数 
据 和 接收 数据 都 仅 用 一 对 〈2 根 ) 世 线 。 


1000Base-TX 和 1000Base-T 规 范 双 绞 心 线 使 用 情况 的 比较 如 图 6-37 
所 示 (注意 区 分 图 中 的 不 同 颜色 ) 。1000Base-T 规 范 中 各 忌 线 的 具体 
作用 如 图 6-38 所 示 ， 每 条 芯 线 上 分 担 的 速率 都 是 250Mbps， 所 以 在 全 双 
工 模式 下 ， 它 可 以 实现 2Gbps 的 传输 速率 。 这 得 益 于 1000Base-T 采 用 了 
一 种 更 加 强大 的 信号 传输 和 编 /解码 方案 一 一 PAM-5 (Pulse Amplitude 
Modulation 5， 脉 冲 调幅 -5) 。PAM-5 编 码 使 用 -2V、-1V、0V、+1V、 
+2V 五 种 电 平 ， 其 中 -2V、-1V、+1V、+2V 这 四 种 电 平 用 于 信号 编码 ， 
0 电 平 用 于 前 向 纠 错 编码 (FEC) 。 而 在 100Base-TX 中 采用 的 是 3 级 
MLT (3Multi-Level Transmission， 多 级 传送 ) 编码 方案 MLT-3， 使 
用 -1V、0V、+1V 三 种 电 平 ， 其 中 -1V、+1V 这 两 种 电 平 用 于 信号 编 
码 ，0 电 平 用 于 前 向 纠 错 编码 。 由 此 可 见 ，PAM-5 编 码 方案 在 链 路 上 较 
MLT-3 编 码 方案 可 以 多 传送 一 倍 的 数据 。 


由 | 


图 6-37 100Base-TX 和 100Base-T 规 范 中 双 绞 芯 线 使 用 比较 
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图 6-38 100Base-T 规 范 中 各 双 绞 心 线 的 作用 
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还 有 一 个 要 注意 的 地 方 就 是 ，1000Base-T 规 范 中 不 采用 交叉 网 
线 ， 只 需 直 通 线 〈 两 端 按 同一 标准 制作 网 线 ) ， 因 为 这 一 规范 中 总 是 
采取 全 双 工 传输 的 ， 任 何 一 根 网 线 都 可 以 同时 发 送 和 接收 数据 。 这 与 
1000Base-TX 是 不 一 样 的 《有 X 的 表示 是 不 同 设备 连接 时 要 采用 交叉 
线 ， 而 没有 X 的 表示 为 不 用 交叉 线 ) 


总 体 而 言 ，1000Base-I 规 范 最 吸引 人 的 地 方 在 于 为 企业 提供 了 一 
种 除 多 模 光 纤 以 太 网 方案 外 的 更 廉价 的 千 兆 方案 ， 用 户 可 以 在 原来 
100Base-T 的 基础 上 进行 平滑 升级 到 1000Base-T。 该 规范 主要 用 于 结构 
化 布线 中 同一 层 建筑 间 的 通信 ， 可 以 利用 现 有 以 太 网 或 快速 以 太 网 已 


铺设 的 UTP 电 组 进行 网 络 升 级 ， 其 可 被 用 做 大 楼 内 的 网 络 主干 ， 大 大 
节省 了 成 本 。 这 是 目 前 最 主要 应 用 的 干 兆 以 太 局 域 网 方案 。 


6.7.3 IEEE 于 兆 以 太 网 物理 层 结构 


尽管 在 以 上 九 种 千 兆 以 太 网 中 有 些 并 不 是 IEEE 发 布 的 ， 但 总 体 上 
来 说 ， 他 们 的 体系 结构 与 IEEE 发 布 的 千 兆 以 太 了 网 规范 类 似 ， 所 以 在 此 
仅 以 IEEE 发 布 的 千 兆 以 太 网 标准 为 例 介绍 其 体系 结构 。 


与 本 章 前 面 介绍 的 标准 以 太 了 网、 快速 以 太 网 物理 层 结构 一 样 ， 于 
兆 以 太 网 的 整个 体系 结构 老 别 主要 体现 在 物理 层 和 MAC 子 层 ，LLC 子 
层 基 本 上 都 是 保持 了 一 致 。 从 体系 结构 上 来 看 ， 千 兆 以 太 网 与 快速 以 
太 网 的 区 别 并 不 是 很 大 ， 主 要 就 是 由 原来 的 MII 接 口 奉 换 成 了 GMII 接 
口 。 图 6-39 所 示 的 古 快 速 以 太 网 体系 结构 与 千 兆 以 太 网 体系 结构 的 比 
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图 “6-39 快速 以 太 网 与 千 兆 以 太 网 体系 结构 的 比较 


快速 以 太 网 体系 结构 与 千 兆 以 太 网 体系 结构 在 物理 层 上 的 主要 区 
别 表现 为 RS 于 层 和 PCS 子 层 之 间 的 接口 发 生 了 改变 ， 由 快速 以 太 网 中 
的 介质 无 关 接口 MID 扩展 为 千 兆 介质 无 关 接 口 (GMI1) 。 其 他 各 子 
层 的 功能 参见 本 章 前 面 介 绍 的 快速 以 太 网 标准 中 的 物理 层 结 构 。 


GMII 的 发 送 和 接收 数据 宽度 由 原来 的 MI 的 半 字 节 (4 位 ) 扩展 到 
一 字 节 (8 位 ) ， 这 样 每 根 必 线 使 用 125MHz 的 时 钟 频率 可 以 实现 
1000Mbps 的 传输 速率 。 另 外 与 MII、AUI 不 同 ，GMII 不 支持 连接 器 和 
电 绕 ， 其 只 是 内 置 作 为 IC 和 IC 之 间 的 接口 。 


另外 ， 千 兆 以 太 网 物理 层 的 PCS 子 层 与 快速 以 太 网 中 的 PCS 子 层 有 
所 区 别 ， 而 且 1000Base-X 子 系列 三 个 规范 物理 层 与 1000Base-T 规 范 物 
理 层 中 的 PCS 子 层 也 不 一 样 ， 前 者 采用 的 是 8B/10B 编 码 方式 ， 而 后 者 
采用 的 是 PAM-5 编 码 方式 。 快 速 以 太 网 100Base-TX 规 范 中 采用 的 是 
4B/5B 编 码 方式 。 


6.8 万 兆 以 太 网 规范 及 体系 结构 


1999 年 底 成 立 了 IEEE 802.3ae 工 作 组 专门 进行 万 兆 以 太 网 (Ten 
Gigabit Ethernet) 技术 (10Gbps) 的 研究 ， 并 于 2002 年 以 IEEE 802.3ae 
标准 的 形式 第 一 次 发 布 万 兆 以 太 网 标准 ， 这 个 标准 是 当时 最 快 的 以 太 
网 标准 。 在 10Gbps 以 太 网 中 ， 最 显著 的 改变 就 是 只 能 与 全 双 工 交换 机 
连接 ， 不 再 文 持 半 双 工 连接 ， 也 不 文 持 CSMA/CD 。 


6.8.1 ”万 兆 以 太 网 规范 


万 兆 以 太 网 标准 和 规范 都 比较 多 : 在 标准 方面 ， 有 2002 年 的 IEEE 
802.3ae，2004 年 的 IEEE 802.3ak，2006 年 的 IEEE 802.3an 和 IEEE 


802.3aq， 以 及 2007 年 的 IEEE 802.3ap 。 


在 万 兆 以 太 了 网 规 苑 方面 ， 仅 由 上 述 IEEE 标 准 中 发 布 的 规范 束 有 10 
多 个 ， 如 2002 年 在 IEEE 802.3ae 标 准 中 发 布 的 基于 光纤 的 规范 包括 : 
10GBase-SR、10GBase-LR、10GBase-ER 、10GBase-LX4、10GBase- 


SW、10GBase-LW、10GBase-EW; 2004 年 在 IEEE 802.3ak 标 准 中 发 布 

的 基于 双 绞 线 的 10GBase-CX4; 2006 年 在 IEEE 802.3an 标 准 发 布 的 基于 
双 绞 铜 线 的 10GBase-T; 2006 年 在 IEEE 802.3aq 标 准 中 发 布 的 基于 光纤 

的 10GBase-LRM; 2007 年 在 IEEE 802.3ap 标 准 中 发 布 的 基于 铜 线 的 


10GBase-KR 和 10GBase-KX4。 除 此 之 外 ， 还 有 一 些 不 是 由 IEEE 发 布 的 
万 兆 以 太 网 规范 ， 如 Cisco 的 10GBase-ZR 和 10GBase-ZW， 这 些 规范 所 
对 应 的 标准 具体 如 图 6-40 所 示 。 
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图 6-40 万 兆 以 太 网 标准 与 对 应 的 规范 
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以 上 这 10 多 种 万 兆 以 太 网 规范 可 以 分 为 三 类 : 一 是 基于 光纤 的 局 
域 万 兆 以 太 网 规范 ， 二 是 基于 双 绞 线 (或 铜 线 的 局 域 万 兆 以 太 网 规 
范 ， 三 古 基 于 光纤 的 广 域 万 粮 以 太 网 规范 。 下 面 分 别 予 以 介绍 。 


1. 基 于 光纤 的 局 域 万 兆 以 太 网 规范 


用 于 局 域 网 的 光纤 万 兆 以 太 网 规范 有 : 10GBase-SR、10GBase- 
LR、10GBase-LRM、10GBase-ER、10GBase-ZR 和 10GBase-LX4 这 六 


个 。 


(1) 10GBase-SR 


10GBase-SR 中 的 SR 是 Short Range 〈 短 距离 ) 的 缩写 ， 表 示 仅 用 于 
短 距离 连接 。 该 规范 支持 编码 方式 为 64B/66B 的 短波 (波长 为 850nm) 
多 模 光纤 (MMEF) ， 有 效 传输 距离 为 2~300m。 但 要 支持 300m 传 输 需 
要 采用 经 过 优化 的 50hm 线 径 OM3 (Optimized Multimode 3， 优 化 的 多 
模 3) 光纤 (没有 优化 的 线 径 50pm 光 纤 称 为 OM2 光 纤 ， 而 线 径 为 
62.5hm 的 光纤 称 为 OM1 光 纤 ) 。 


(2) 10GBase-LR 


10GBase-LR 中 的 LR 是 Long Range (长 距离 ) 的 缩写 ， 表 示 主 要 用 
于 长 距离 连接 。 该 规范 支持 编码 方式 为 64B/66B 的 长 波 (1310nm) 单 
模 光 纤 (SMF) ， 有 效 传 输 距 离 为 2m~10km， 事 实 上 最 高 可 达到 
25km ° 


(3) 10GBase-LRM 


10GBase-LRM 中 的 LRM 是 Long Reach Multimode (长 距离 延伸 多 
点 模式 ) 的 缩写 ， 表 示 主 要 用 于 长 距离 的 多 点 连接 模式 ， 对 应 的 标准 
为 2006 年 发 布 的 IEEE 802.3aq， 采 用 64B/66B 编 码 方式 。 采 用 该 规范 
时 ， 在 1990 年 以 前 安装 的 线 径 62.5hm 多 模 光 纤 FDDI 网 络 和 100Base-FX 
网 络 中 的 有 效 传输 距离 为 220m， 而 在 OM3 光 纤 中 可 达 260m， 在 连接 长 
度 方面 ， 不 如 以 前 的 10GBase-LX4 规 范 ， 但 是 它 的 光纤 模块 比 10GBase- 
LX4 规 范 光纤 模块 具有 更 低 的 成 本 和 更 低 的 电源 消耗 。 


(4) 10GBase-ER 


10GBase-ER 中 的 ER 是 Extended Range 〈 超 长 距离 ) 的 缩写 ， 表 示 
连接 距离 可 以 非常 长 。 该 规范 文 持 编码 方式 为 64B/66B 的 超 长 波 
(1550nm) 单 模 光纤 (SMF) ， 有 效 传输 距离 为 (2~40) km 。 


(5) 10GBase-ZR 


10GBase-ZR 中 的 ZR 是 Ze best Range (最 长 距离 ; 的 缩写 ， 表 示 连 
接 距 离 最 长 ， 可 达 80km， 是 Cisco 的 一 个 私有 万 兆 以 太 网 标准 。 它 使 用 
的 也 是 超 长 波 (1550nm) 单 模 光 纤 (SMF) 。 


(6) 10GBase-LX4 


10GBase-LX4 规 范 在 IEEE 802.3ae 标 准 中 发 布 ， 设 计 通 过 波 分 复 用 
技术 采用 4 束 光波 通过 单 对 光学 电缆 来 发 送信 号 ， 采 用 8B/10B 编 码 方 
式 。10GBase-LX4 工 作 波长 为 1310nm， 使 用 多 模 或 单 模 暗 光纤 ， 主 要 
适用 于 需要 在 一 个 光纤 模块 中 同时 文 持 多 模 和 单 模 光 纤 的 环境 。 多 模 
光纤 传输 距离 为 240~300m， 单 模 光 纤 10km 以 上 ， 根 据 电缆 类 型 和 质 
量 ， 还 能 达到 更 远 的 距离 。 


2. 基 于 双 绞 线 (或 铜 线 ) 的 局 域 网 万 兆 以 太 网 规 苑 


在 2002 年 发 布 的 几 个 万 兆 以 太 网 规范 中 并 没有 文 持 钢 线 这 种 廉价 
传输 介质 的 ， 但 事实 上 ， 像 双 绥 线 这 类 铜 线 在 局 域 网 中 的 应 用 是 最 普 


遍 的 ， 其 不 仅 成 本 低 ， 还 容易 维护 ， 所 以 在 近 几 年 相继 推出 了 多 个 基 
于 双 绞 线 (6 类 以 上 ) 的 万 兆 以 太 网 规范 。 它 们 包括 10GBase-CX4、 
10GBase-KX4、10GBase-KR、10GBase-T。 下 面 分 别 予 以 简单 介绍 。 


(1) 10GBase-CX4 


10GBase-CX4 规 范 使 用 IEEE 802.3ae 中 定义 的 XAUI (万 兆 附 加 单 
元 接口 ) 和 用 于 InfiniBand 中 的 4X 连 接 器 ， 传 输 介 质 称 为 CX4 铜 缆 (其 
实 就 是 一 种 屏蔽 双 绞 线 ) 。 它 的 有 效 传输 距离 仅 为 15m。 


10GBase-CX4 规 范 不 是 利用 单个 铜 线 链 路 传送 万 兆 数据 ， 而 是 使 
用 4 人 台 发 送 器 和 4 台 接 收 需 来 传送 万 兆 数据 ， 并 以 差分 方式 运行 在 同 轴 
电线 上 ， 每 台 设 备 利用 8B/10B 编 码 ， 以 每 信道 3.125GHz 的 频 市 传送 
2.5Gbps 的 数据 。 这 需要 在 每 条 电缆 组 的 总 共 8 条 双 同 轴 信 道 的 每 个 方向 
上 有 4 组 差分 线 缆 对 。 另 外 ， 与 可 在 现场 端 接 的 5 类 、 超 5 类 双 纺 线 不 
同 ，CX4 的 线 缆 需 要 在 工厂 端 接 ， 因 此 客户 必须 指定 线 缆 长 度 。 线 绝 
越 长 一 般 直 径 就 越 大 。 


(2) 10GBase-KX4 和 10GBase-KR 


10GBase-KX4 和 10GBase-KR 两 个 规范 主要 用 于 设备 背 板 连接 中 ， 
如 刀片 服务 器 、 路 由 器 和 交换 机 的 集群 线路 卡 ， 所 以 又 称 背 板 以 太 
网 。 


万 兆 背 板 连 接 目前 已 经 存在 并 行 和 串 行 两 种 版 本 : 并 行 版 本 
(10Gbase-KX4 规 范 ) 是 背 板 的 通用 设计 ， 将 万 兆 信号 拆 分 为 4 条 通道 
(类 似 XAUI) ， 每 条 通道 的 带宽 都 是 3.125Gbps。 串 行 版 本 (10GBase- 

KR 规范 ) 中 只 定义 了 一 条 通道 ， 采 用 64/66B 编 码 方式 实现 10Gbps 高 速 
传输 。10Gbase-KX4 使 用 与 10GBase-CX4 规 范 一 样 的 物理 层 8B/10B 编 
码 ，10GBase-KR 使 用 与 70GBase-LR/ER/SR 这 3 个 规范 一 样 的 物理 层 
64B/66B 编 码 。 


(3) 10GBase-T 


10GBase-T 是 基于 屏蔽 或 非 屏 蔽 双 绞 线 ， 主 要 用 于 局 域 网 的 万 浪 以 
太 网 规范 ， 最 长 传输 距离 为 100m。 这 可 以 算是 万 兆 以 太 网 一 项 早 命 性 
的 进步 ， 因 为 在 此 之 前 ， 一 直 认 为 在 双 绥 线 上 不 可 能 实现 这 么 高 的 传 
输 速率 ， 原 因 就 是 运行 在 这 么 高 工作 频率 (至 少 为 500MHz) 基础 上 损 
耗 太 大 。 但 标准 制定 者 依靠 以 下 4 项 技术 构件 使 10GBase-T 变 为 现实 : 
损耗 请 除 、 模 拟 到 数字 转换 、 线 统 增 强 和 编码 改进 。 


在 编码 方面 ，10GBase-T 不 是 采用 原来 1000Base-T 的 PAM-5 编 码 方 
式 ， 而 是 采用 PAM-8 编 码 方式 ， 文 持 833Mbps 和 400MHz 市 宽 ， 对 布线 
系统 的 带宽 要 求 也 相应 地 修改 为 500MHz。 如 果 仍 采用 PAM-5 的 
10GBase-T， 对 布线 带宽 的 需求 是 625MHz。 在 连接 器 方面 ，10GBase-T 
使 用 已 广泛 应 用 于 以 太 网 的 650 MHz 版 本 RJ-45 连 接 器 。 在 6 类 线 上 最 长 
有 效 传输 距离 为 55m， 而 在 6a 类 线 上 可 以 达到 100m 。 


3. 基 于 光纤 的 广域网 万 兆 以 太 网 规范 


10Gbps 以 太 网 一 个 最 大 改变 就 是 它 不 仅 可 以 在 局 域 网 中 使 用 ， 还 
可 应 用 于 广域网 中 ， 其 对 应 的 规范 包括 10GBase-SW、10GBase-LW、 
10GBase-EW 和 10GBase-ZW (此 为 Cisco 私 有 标准 ) 。 这 4 个 广域网 
10Gbps 广 域 以 太 网 规范 专 为 工作 在 OC-192/STM-64 SDH/SONET 环 境 而 
设置 的 ， 使 用 SDH (Synchronous Digital Hierarchy， 同 步 数 字体 
系 ) /SONET (Synchronous optical networking， 同 步 光 纤 网 络 ) 帧 ， 传 
输 速率 为 9.953 Gbps。 它 们 所 使 用 的 光纤 类 型 和 有 效 传输 距离 分 别 对 应 
于 前 面 介绍 的 应 用 于 局 域 网 中 的 10GBase-SR、10GBase-LR、10GBase- 


ER 和 10GBase-ZR 规 范 。 


表 6-9 所 示 综 合 了 以 上 介绍 的 所 有 10Gbps 以 太 网 规范 ， 在 实际 的 网 
络 系统 设计 中 ， 就 可 以 针对 具体 的 节点 环境 和 网 络 需求 来 对 应 选择 
了 。 当 然 ， 目 前 10Gbps 以 太 网 主要 是 在 骨干 网 络 中 采用 ， 在 一 般 的 企 
业 局 域 网 中 仍 很 少见 到 。 


表 6-9 万 兆 以 太 网 规范 比较 


万 兆 以 太 网 规范 使 用 的 传输 介质 应 用 领域 
10GBase-LX4 ”| 1300nm 单 模 或 者 多 模 光纤 
10GBase-CX4 ls5m 


| 
i ike 

on [mR ND | | 
oD mm | ww | 


6.8.2 ”万 兆 以 太 了 网 的 物理 层 结构 


在 许多 万 兆 以 太 网 规范 中 ， 也 对 应 了 许多 不 同类 型 的 万 兆 以 太 网 


物理 层 ， 但 总 体 类 型 还 是 与 最 初 于 2002 年 发 布 的 几 类 万 兆 以 太 网 规范 
差不多 。 下 面 分 基于 光纤 传输 介质 万 浪 以 太 网 规范 物理 层 和 基于 铜 线 
传输 介质 万 兆 以 太 网 规范 物理 层 两 种 类 型 进行 介绍 。 


( 仪 包括 10GBase-X 规 范 ) 
LR 和 10GBase-ER 等 3 个 规范 ) 和 10GBase-W (包括 10GBase-SW、 


10GBase-LW 和 10GBase-EW 等 3 个 规范 ) 


在 IEEE 发 布 的 万 兆 以 太 网 规范 中 ， 主 要 是 三 大 类 ， 即 10GBase-X 


、10GBase-R (包括 10GBase-SR、10GBase- 


结构 如 图 6-41 所 示 (注意 其 中 用 深 颜 色 标 注 的 部 分 ) 。 


图 6-41 


。 这 三 大 类 规范 所 对 应 的 体系 


X 数据 链 路 层 


计算 机 系统 总 线 计算 机 系统 总 线 
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10GBase-X ”下 、 从 输 介质 10GBase-R ”下 传输 介质 
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PCS( 64B/66B ) 


WIS 子 层 


PMA 子 层 


MDI 子 层 


10GBase-W 


所 传输 介质 


三 个 万 兆 以 太 网 规范 子 系列 的 体系 结构 


通过 与 图 6-39 所 示 的 千 兆 以 太 网 体系 结构 比较 ， 从 层次 上 来 看 ， 主 
要 区 别 如 下 : 


1) 把 原来 千 兆 以 太 网 的 GMII 升 级 替换 成 了 XGMII (10 Gigabit 
Media Independent Interface，10G 介 质 无 关 接 口 ) 。 


XGMII 与 千 兆 以 太 网 的 GMII 一 样 ， 也 是 位 于 收发 辟 内 部 ， 但 它 是 
由 全 新 的 芯片 完成 的 ， 以 实现 支持 10Gbps 传 输 速率 。XGMII 功 能 由 一 
个 具有 74 条 信号 线 (相当 于 74bit 宽 度 ) 的 接口 必 片 完成 ， 其 中 的 64 条 
数据 线 用 于 数据 的 收发 〈 收 、 发 各 32 条 ) ， 其 余 的 为 时 钟 和 控制 信号 
位 ， 是 连接 以 太 网 MAC 子 层 和 物理 层 的 桥梁 。 


2) 在 10GBase-R 子 系列 中 的 3 个 规范 中 的 物理 层 ， 除 了 上 述 接 口 换 
成 为 XGMII 外 ， 还 有 一 个 区 别 束 是 PCS 子 层 的 编码 方式 由 原来 的 
8B/10B 改 变 成 了 64B/66B 。 


3) 在 10GBase-W 子 系列 中 的 3 个 规范 中 相对 于 兆 以 太 网 物理 层 的 
改变 更 大 ， 除 了 在 10GBase-R 于 系列 中 的 两 处 改变 外 ， 还 在 PCS 子 层 与 
PMA 子 层 之 间 增 加 了 一 个 新 的 子 层 一 一 WIS (WAN Interface Sublayer， 
WAN 接 口 ) 子 层 。 


WIS 子 层 用 于 在 广域网 中 产生 适 配 ANSI 定 义 的 SONET STS-192c 传 
输 格 式 ， 或 适 配 ITU 定 义 SDH VC-4-64c 容 器 速率 的 以 太 网 数据 流 ， 这 


就 使 万 兆 以 太 网 设备 与 同步 光纤 网 络 (SONET) STS-192c 传 输 格 式 相 
互 兼 容 。 


其 他 各 子 层 的 功能 与 千 兆 以 太 网 体系 结构 中 的 对 应 的 各 子 层 类 
似 ， 可 参见 对 应 各 子 层 的 功能 说 明 ， 只 不 过 在 PCS 子 层 中 所 采用 的 编码 
与 干 睁 以 太 网 不 一 样 ， 参 见 图 6-39 所 示 。 


6.9 IEEE 802.1d 协 议 


IEEE 802.1d 也 就 是 我 们 通常 所 说 的 STP (Spanning Tree Protocol， 
生成 树 协 议 ) 。 其 设计 目的 就 是 要 使 交换 网 络 中 没有 二 层 环 路 。 在 这 
里 首先 我 们 介绍 什么 是 环 路 。 


6.9.1 理解 “网 络 环 路 ” 


这 里 所 说 的 环 路 就 是 指 网 络 环 路 。 它 又 分 为 二 层 环 路 和 三 层 环 路 
两 种 。 二 层 环 路 是 指 在 二 层 交 换 网 络 中 ， 网 络 广播 信息 在 网 络 中 形成 
的 一 个 封闭 的 环 路 。 如 图 6-42 所 示 ，SW1 和 SW2 这 两 个 交换 机 之 间 有 两 
条 链 路 连接 。 现 假设 SW1 的 F0/3 端 口 收 到 了 来 自 PC1 的 一 个 广播 包 ， 它 
会 通过 FO/1 和 F0/2 端 口 分 别 向 SW2 的 FO/1 和 F0/2 端 口 发 送 ， 同 样 当 SW2 
的 FO01 和 F0/2 端 口 在 收 到 广播 包 后 也 会 分 别 再 同 SW1 的 FO01 和 F0/2 病 口 
发 送 广播 包 ， 以 此 反复 就 形成 了 一 个 恶性 死 循环 ， 即 形成 广播 风 骏 ， 
造成 了 大 量 网 络 设备 和 带宽 资源 的 浪费 。 


| F0/1 
a | F0/3 F0/3 < 站 
| 二 > Ey 
> SWi F0/2 SW2 


PC1 EC2 


图 6-42 元 余 链 路 二 层 环 路 示例 


上 面 所 说 的 是 广播 包 在 二 层 环 路 中 的 传播 情形 ， 其 实 即使 是 从 PC1 
发 送 到 PC2 的 单 播 包 ， 因 为 SW1 和 SW2 有 两 条 链 路 ， 这 样 在 SW2 上 可 能 
会 同时 收 到 来 自 SW1 的 FO001 和 F0/2 端 口 发 来 的 包 ， 最 终 造 成 重复 包 ， 也 
浪费 了 网 络 设备 和 和 带宽 资源 。 在 如 图 6-43 所 示 的 封闭 环 交 换 网 络 中 同样 
存在 这 样 的 情况 ， 大 家 可 以 目 己 分 析 一 下 。 


图 6-43 封闭 的 二 层 环 路 示例 


而 三 层 环 路 则 是 指 当 原 路 由 意外 不 能 工作 时 ， 造 成 路 由 通告 错误 
所 形成 的 一 个 恶性 路 由 循环 。 当 然 主 要 在 RIP、IGRP 这 两 种 动 个 路 由 协 
议 中 才 会 出 现 这 种 情况 。 


6.9.2 STP 简介 


“广播 风暴 ”的 现象 只 存在 于 两 点 之 间 存 在 元 余 链 路 (也 就 是 从 一 
个 节点 到 达 另 一 节点 存在 多 条 路 径 ) 的 网 络 之 中 。 元 余 链 路 在 现实 网 
络 设计 中 大 量 存 在 。 如 图 6-44 所 示 ， 核 心 层 、 沪 聚 层 的 交换 机 间 都 是 有 
见 余 设计 的 。 


Switch 1 Switch 2 


核心 层 


隐 余 连接 


接 入 层 


Switch6 Switch7 Switch8 Switch9 Switch 10 Switch 11 


图 6-44 宛 余 连接 设计 示例 


本 来 这 样 设计 的 目的 是 想 当 菏 一 条 链 路 失效 时 ， 必 一 条 元 余 的 链 
路 能 够 马上 接管 所 有 的 工作 〈 如 HSRP、VRRP 协 议 的 热 备 应 用 ) 。 但 
征 ， 在 实际 工作 中 这 些 隐 余 连 接 还 会 融 来 广播 风暴 隐患 。 如 从 图 6-44 中 


的 Switch 6 交换 机 发 送 的 数据 要 到 达 Switch 1， 可 以 有 多 条 不 同 的 路 
径 ， 其 中 包括 Switch 6~ Switch 3 Switch 1、Switch 6 一 Switch 

3 一 Switch 4 Switch 1、Switch 6— Switch 3 —» Switch 4 一 Switch 

5 一 Switch 2 一 Switch 1 这 3 条 。 这 样 一 来 ， 当 从 Switch 6 发 送 一 个 请 求 数 
据 包 到 Switch 1 时 ， 就 可 能 从 以 上 3 条 路 径 中 同时 流出 ，Switch 1 交换 机 
上 可 能 会 收 到 多 个 重复 的 包 ， 这 显然 是 不 需要 的 。 本 示例 只 是 一 个 很 
简单 的 结构 ， 如 果 结 构 更 复杂 的 话 ， 宛 余 连 接 会 更 多 ， 对 应 的 元 余 链 
路 也 就 更 多 ， 所 带 来 的 广播 风 暴 将 更 大 。 


除了 广播 风 骏 的 影响 外 ， 这 人 么 多 元 余 链 路 ， 还 可 能 形成 网 络 数据 
发 送 和 接收 死 循环 。 同 样 以 图 6-40 为 例 。 在 以 上 3 条 路 人 径 中 ， 从 Switch 1 
上 发 送 到 Switch 6 的 数据 包 ， 可 能 束 不 会 到 达 Switch 6， 而 是 直接 在 
Switch 1 » Switch 3 » Switch 4 —» Switch 1 、 Switch 1 —» Switch 4 一 Switch 
3 一 Switch 1、Switch 1 Switch 2 一 Switch 5 一 Switch 4 一 Switch 1 等 多 个 


封闭 的 环 路 上 循环 。 


为 了 解决 广播 风暴 和 网 络 死 循环 这 两 个 在 二 层 数 据 网 络 中 存在 的 
主要 弊端 ，IEEE (电气 和 电子 工程 师 学 会 ) 在 基于 思科 早期 开发 的 生 
成 树 技 术 基 础 上 发 布 了 IEEE 802.1d 协 议 标 准 ， 也 就 是 我 们 通常 所 说 的 
STP 。 


STP 走 一 个 确保 整个 交换 网 络 无 环 路 拓扑 结构 的 OSI 二 层 协议 。 它 
允许 在 网 络 设 计 中 包括 元 余 链 路 ， 以 提供 在 主 链 路 失效 时 目 动 接替 其 


工作 的 备份 链 路 ， 同 时 又 不 会 生成 二 层 环 路 。 必 须 避 人 免 二 层 环 路 ， 否 
则 可 能 导致 数据 包 在 网 络 中 循环 传输 。STP 束 像 其 名 称 一 样 ， 它 在 一 个 
由 网 桥 或 交换 机 连接 的 网 状 网 络 内 部 创建 一 棵 生成 树 ， 茜 止 不 属于 树 
的 那些 链 路 ， 使 得 任意 两 个 网 络 世 点 间 仅 有 一 条 活动 的 路 径 。STP 将 两 
点 之 间 存 在 的 多 条 路 经 划分 为 通信 链 路 和 备份 链 路 ， 并 规定 数据 的 转 
发 只 在 通信 链 路 上 进行 ， 而 备份 链 路 只 用 于 链 路 的 侦 听 ， 只 有 在 发 现 
通信 和 链 路 径 失 效 时 ， 才 目 动 将 通信 切换 到 备份 链 路 上 。 


用 于 正常 数据 转发 的 “通信 和 链 路 ”往往 是 最 短 的 路 径 ， 如 图 6-44 所 示 
示例 中 的 Switch 6 一 Switch 3 一 Switch 1 这 条 路 径 。 但 是 ，STP 并 不 是 全 
部 禁用 其 余 元 余 链 路 ， 而 只 是 在 正常 工作 中 让 它们 处 于 侦 听 状态 ， 妆 
活动 链 路 失效 时 才 接替 活跃 链 路 的 工作 。 这 样 就 可 以 达到 既 不 会 因为 
隐 余 链 路 而 形成 广播 风暴 ， 也 不 会 因为 没有 隐 余 链 路 而 造成 网 络 循 
环 ， 从 而 提高 了 网 络 的 可 用 性 。 


6.9.3 STP 的 基本 工作 原理 


IEEE 802.1d STP 是 把 整个 交换 网 络 看 成 一 个 生成 树 实例 (也 就 是 
一 棵 “ 树 ”) ， 称 之 为 CST (Common Spanning Tree， 公 共生 成 树 ) 。 在 
这 里 ， 我 们 先 要 理解 为 什么 要 以 “ 树 ” 来 形容 STP 所 形成 的 拓扑 结构 。 


我 们 知道 ， 目 然 弄 的 树 是 由 树 根 、 树 干 、 树 校 和 树叶 组 成 的 。 我 
们 可 以 把 树叶 比 作 网 络 用 户 的 主机 或 服务 器 (连接 在 接 入 层 交 换 机 的 
端口 上 ) ， 把 树 校 比 作 网 络 中 接 入 层 交 换 机 〈 连 接 在 汇聚 层 交 换 机 的 
端口 上 ) ， 把 树干 比 作 网 络 中 汇聚 层 交 换 机 (连接 在 核心 层 交 换 机 的 
端口 上 ) ， 把 树 根 比 作 网 络 中 核心 交换 机 ， 如 图 6-45 所 示 。 从 图 中 可 以 
看 出 ， 网 络 中 的 任何 节点 〈 端 口 ) 之 间 的 连接 都 不 存在 环 路 ， 因 为 任 
意 两 个 节点 间 的 连接 只 有 一 条 路 径 ， 也 就 是 我 们 通常 所 说 的 “单线 连 
接 ”。STP 的 目的 惑 是 要 把 一 个 物理 网 络 拓扑 结构 变 成 这 种 无 环 路 的 逻 
辑 拓 扑 结构 。 
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SS “树干 ”相当 于 
汇聚 层 交 换 机 
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图 6-45 STP 生成 树 模拟 示例 


在 如 图 6-42 所 示 的 示例 中 ， 在 SW1 和 SW2 之 间 存 在 一 条 宛 余 链 路 。 
从 PC1 发 出 的 一 个 广播 或 者 多 播 包 可 能 会 在 两 个 交换 机 之 间 循 环 ， 这 在 
前 面 已 作 了 分 析 。 但 是 ， 如 有 果 在 两 个 交换 机 上 运行 了 STP， 则 其 中 一 条 
链 路 会 自动 断 开 。 这 时 在 SW1 和 SW2 之 间 就 只 有 一 条 路 径 ， 从 PC1 发 出 
的 广播 或 者 多 播 包 就 不 会 在 两 个 交换 机 之 间 循 环 了 ， 消 除了 网 络 环 
路 。 


那么 STP 又 是 如 何 做 到 在 有 元 余 链 路 的 情况 下 同时 避免 环 路 发 生 的 
呢 ? 也 就 是 STP 如 何 把 一 个 有 环 路 的 物理 交换 网 络 转换 成 逻辑 意义 上 无 


环 路 的 树 形 交换 网 络 呢 ? 其 实 原理 很 商 单 ， 它 采用 两 项 主要 技术 : 一 
征 通 过 选举 ， 使 得 交换 网 络 中 的 各 个 交换 机 处 于 特定 的 角色 ， 残 像 图 6- 
45 中 的 各 交换 机 分 别 为 位 于 树 根 的 核心 交换 机 ， 位 于 树干 的 汇聚 交换 
机 ， 位 于 树枝 的 接 入 交换 机 ， 这 样 束 可 以 使 整个 交换 网 络 拓扑 结构 呈 
一 个 树 形 结构 ， 男 外 一 项 技术 就 是 把 交换 机 间 连 接 的 端口 (连接 主机 
的 端口 不 算 在 内 ) 划分 为 不 同 角色 ， 各 个 交换 机 端口 又 可 设 定 成 几 种 
等 定 状 态 ， 使 可 能 形成 环 路 的 一 些 交 换 机 端口 在 正 闻 工作 时 处 于 阻塞 
状态 ， 同 时 指定 每 个 交换 机 与 上 级 交换 机 连接 的 固定 端口 。 


在 交换 机 角色 选举 中 ， 也 就 是 在 整个 交换 网 络 中 选举 出 一 个 根 交 
换 机 〈 网 桥 时 代称 之 为 根 桥 ，Root Bridge) ， 所 连接 的 每 个 网 段 的 交 
换 机 为 指定 交换 机 (Designated Bridge) ， 或 者 称 之 为 非 根 交换 机 。 根 
交换 机 一 般 是 位 于 核心 层 (需要 经 过 选举 确定 ) ， 相 当 于 树 根 ， 主 要 
用 于 为 下 面 各 个 网 段 交 换 机 提供 服务 ， 以 及 作为 整个 网 络 的 出 口 。 然 
后 又 为 各 交换 机 定义 了 根 端口 (Root Port) 和 指定 端口 (Designated 
Port) 两 种 主要 的 端口 角色 。 根 端口 束 是 非 根 交 换 机 到 达 根 交换 机 的 最 
短路 径 (也 需要 选举 确定 ) 的 那个 端口 ， 指 定 下 级 交换 机 要 访问 根 交 
换 机 时 必须 从 这 个 端口 出 发 ， 而 不 能 从 其 他 端口 ， 所 以 根 端口 仅 位 于 
非 根 交 换 机 上 。 指 定 端口 则 有 两 种 情况 ， 根 交换 机 上 的 所 有 连接 交换 
机 的 端口 都 可 以 是 指定 端口 ， 因 为 它们 直接 在 根 交 换 机 上 ， 每 个 用 于 
连接 交换 机 的 端口 都 连接 了 一 个 网 段 ， 指 定 交换 机 上 的 指定 端口 是 指 
与 下 级 交换 机 根 端口 连接 的 那个 端口 。 每 个 指定 交换 机 只 有 一 个 根 端 


口 ， 但 可 以 有 多 个 指定 端口 ， 因 为 一 个 交换 机 可 以 连接 多 个 网 段 (每 


Fs pi 


个 交换 机 端口 可 以 连接 一 个 网 段 } ， 但 每 个 网 段 只 能 一 个 指定 端口 。 


同时 ，STP 中 包括 的 端口 状态 有 : 阻塞 (Blocking) 状态 、 侦 听 
(Listening) 状态 、 学 习 (Learmning) 状态 、 转 发 (Forwarding) 状 
态 、 禁 止 (Disabled) 状态 。 在 交换 机 上 所 有 交换 机 间 连 接 的 端口 中 只 
有 根 端口 和 指定 端口 是 活跃 〈 非 “禁止 ? 状 态 ) 的 ， 其 他 交换 机 间 连 接 
的 端口 都 是 呈 禁 止 状态 。 数 据 的 转发 路 径 就 是 : 由 下 级 非 根 交换 机 的 


指定 剖 口 到 上 级 非 根 交换 机 的 根 端 口 ， 一 直到 根 交 换 机 的 指定 闹 口 。 
这 样 束 可 避免 二 层 环 路 的 发 生 。 


在 图 6-44 所 示 的 网 络 中 ， 各 交换 机 角色 以 及 端口 角色 如 图 6-46 所 
示 ， 当 然 这 些 都 是 需要 经 过 选举 的 ， 具 体 选 举 原理 大 家 可 以 参见 笔者 
编著 的 《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 (第 2 版 ) 一 书 。 
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图 6-46 _ STP 交 换 机 和 端口 角色 示例 
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6.9.4 STP 的 不 足 和 增强 拉 术 


STP 协 议 的 算法 广泛 运用 于 二 层 以 太 网 的 收 合 (收敛 是 指 从 网 络 
上 拓扑 结构 有 了 变化 开始 到 整个 网 络 设备 中 的 信息 重新 一 致 为 止 的 整 
个 过 程 ， 这 个 过 程 所 用 时 间 称 为 收敛 时 间 ) ， 但 是 由 于 它 是 局 域 网 的 
初期 开发 的 技术 ， 所 以 它 也 存在 着 以 下 几 个 不 足 。 


(1) 二 层 数据 网 的 收敛 时 间 过 长 


根据 IEE 802.1d 协 议 的 算法 ， 每 个 节点 的 初始 化 时 间 约 为 308， 整 
个 拓扑 的 收敛 将 会 在 30~50s 之 间 ， 即 使 是 一 个 以 太 网 端口 插入 计算 机 
也 需要 这 个 过 程 。 而 我 们 知道 在 关键 网 络 中 ， 如 主机 核心 机 房 的 连 
接 ， 用 户 期 望 的 值 往往 要 短 得 多 。 


(2) 网 络 拓扑 容易 引起 全 局 波动 


由 于 IEEE 802.1d 协 议 中 没有 域 的 概念 ， 网 络 中 用 户 增 加 或 减少 设 
备 、 设 备 配 置 的 改变 往往 会 引起 全 局 不 必要 的 流动。 用户 如 采 改 变 其 
设备 参数 甚至 可 能 引起 根 交 换 机 的 改变 ， 从 而 造成 通信 网 络 的 中 断 ， 
这 使 得 用 户 在 大 规模 的 数据 网 络 中 不 敢 轻 易 使 用 IEEE 802.1d 协 议 的 算 
法 。 


(3) 缺乏 对 现 有 多 VLAN 环 境 的 支持 


IEEE 802.1d 协 议 是 针对 整个 交换 网 络 而 言 的 ， 也 束 是 整个 交换 网 
络 就 是 一 个 生成 树 实例 〈 称 为 单 生成 树 ，SST) ， 没 有 考虑 存在 多 个 
VLAN 的 情形 。 这 样 一 方面 不 便于 基于 VLAN 来 优化 整个 交换 网 络 拓 
扑 结构 ， 男 一 方面 不 便于 在 复杂 网 络 中 消除 环 路 的 实现 。 


针对 以 上 这 些 STP 协 议 目 喘 的 不 足 ， 网 络 设备 制造 商 开 发 了 许多 
增强 的 生成 树 技 术 ， 如 提高 收敛 效率 的 Rapid-STP (RSTP) ，Cisco 基 
于 一 个 VLAN 的 PVST (每 YLAN 生 成 树 ) 、PVST+、Rapid-PVST+， 
基于 多 个 VLAN 的 多 生成 树 MSTP 等 。 具 体 大 家 可 以 参见 笔者 编著 的 
《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 (第 2 版 ) 一 书 。 


6.10 IEEE 802.1q 协 议 


VLAN (Virtual Local Area Network， 虚 拟 局 域 网 ) 对 应 的 技术 标 
准 是 IEEE 802.1q9， 是 1999 年 6 月 由 IEEE 委 员 会 正式 颁布 实施 的 ， 而 最 
早 的 VLAN 技 术 是 在 1996 年 由 Cisco (思科 ) 公司 提出 的 。 随 着 十 多 年 
来 的 发 展 ，VLAN 技 术 得 到 广泛 的 文 持 ， 在 大 大 小 小 的 企业 网 络 中 广 
泛 应 用 ， 成 为 当前 最 为 热门 的 一 种 以 太 局 域 网 技术 。VLAN 属 于 
OSIRM 二 层 技术 ， 在 同一 VLAN 内 部 是 通过 数据 链 路 层 (OSVRM 第 
二 层 ) 进行 通信 的 。 


6.10.1 划分 VLAN 的 目的 


在 早期 的 以 太 网 中 ， 并 没有 VLAN 技 术 ， 所 以 在 图 6-24 中 所 列 的 
以 太 网 帧 格式 中 没有 添加 用 于 标记 帧 的 VLAN 信 息 的 字段 。 那 后 来 义 
征 基 于 什么 原因 开发 了 这 种 VLAN 技 术 呢 ? 


说 到 这 里 ， 我 们 首先 要 知道 ，VLAN 的 主要 用 途 是 什么 。 


VLAN 的 主要 用 途 束 是 把 一 个 大 的 交换 网 络 划 分 成 多 个 小 的 交换 
网 络 。 那 为 什么 要 划分 成 小 的 交换 网 络 呢 ? 原来 ，VLAN 可 以 隔离 二 
层 通信 ， 也 束 是 不 同 VLAN 中 的 主机 是 不 能 直接 进行 二 层 通信 有 的。 这 
样 束 可 以 达到 一 个 不 划分 VLAN 的 交换 网 络 中 不 能 达到 的 二 层 主机 隔 


离 的 目的 ， 因 为 在 没有 采用 VLAN 技 术 的 交换 网 络 中 ， 各 主机 都 是 可 
以 直接 进行 二 改 通 信 的 。 但 这 仍 不 是 划分 VYLAN 的 主要 目的 。 


那 隔离 二 层 通信 的 真正 目的 是 什么 呢 ? 那 就 是 想 缩 小 广播 域 ， 诚 
小 二 层 网 络 中 广播 流量 对 整个 交换 网 络 的 影响 。 我 们 已 经 知道 ， 在 区 
换 网 络 中 ， 如 果 在 交换 机 缓存 ARP 表 项 中 找 不 到 帧 中 的 目的 MAC 地 
址 ， 融 会 在 整个 交换 网 络 中 进行 广播 。 由 于 交换机 的 缓存 容量 有 限 ， 
加 上 ARP 表 项 也 有 保存 时 间 ， 所 以 在 较 大 交换 网 络 中 ， 广 播 可 能 是 经 
党 要 发 生 的 ， 可 以 说 是 不 可 避免 的 。 


同时 我 们 又 知道 ,广播 通 信和 只 在 本 网 段 内 进行 ， 不 能 通过 路 由 
絮 ， 或 者 其 他 三 层 设 备 跨 网 段 进行 广播 ， 因 为 广播 通信 和 属于 二 层 通 
信 。 正 因 如 此 ， 才 想到 用 VLAN 来 缩小 广播 域 。 试 想 一 下 ， 一 个 大 型 
的 交换 网 络 ， 一 旦 有 广播 流量 ， 整 会同 交换 网 络 中 的 所 有 节点 复制 并 
发 送 一 个 广播 包 ， 这 样 就 会 给 整个 网 络 市 来 不 小 的 负 和 何 ， 可 能 会 影响 
正常 的 数据 交换 。 如 琳 划 分 成 了 一 个 个 VLAN， 每 个 VLAN 相 当 于 一 
个 小 的 独立 二 层 交 换 网 络 ， 也 就 是 一 个 小 的 广播 域 ， 这 样 每 个 VLAN 
中 的 广播 包 避 ® 只 会 在 本 VLAN 中 广播 ， 影响 范畴 和 程度 目 然 束 会 大 大 
降低 。 


6.10.2 ”理解 VLAN 的 形成 和 工作 原理 


VLAN 可 按照 功能 、 项 目 组 、 部 门 、IP 子 网 、 网 络 协议 或 者 应 用 策 
略 等 方式 对 不 同 用 户 进行 分 组 ， 而 可 以 不 考虑 用 户 的 实际 物理 位 置 。 
VLAN 具 有 与 物理 交换 网 络 相同 的 属性 ， 但 是 可 以 聚合 即使 不 在 同一 个 
物理 网 段 中 的 终端 站 点 。 在 VLAN 的 配置 与 使 用 中 ， 因 为 许多 读者 朋友 
并 没有 真正 了 解 VLAN 的 形成 原理 ， 所 以 导致 一 些 VLAN 配 置 和 VLAN 
路 由 、 桥 接 出 现 故 障 时 读者 无 法 理解 故障 原因 。 


1. 同 一 物理 交换 机 中 的 VLAN 


其 实 理 解 VLAN 这 个 术语 的 天 键 束 是 要 理解 “虚拟 * 这 两 个 字 。 虚 拟 
表示 VLAN 所 组 成 的 是 一 个 虚拟 或 者 说 是 逻辑 的 LAN， 并 不 是 一 个 物理 
LAN。 一 个 交换 机 中 的 各 个 VLAN 可 以 理解 为 一 个 个 虚拟 交换 机 ， 如 图 
6-47 所 示 的 物理 交换 机 中 就 划分 了 五 个 VLAN， 相 当 于 有 五 个 相互 只 有 
逻辑 连接 关系 的 虚拟 交换 机 。 
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图 6-47 一 台 物 理 交 换 机 中 划分 的 多 个 VLAN 


其 实 我 们 只 要 把 一 个 VLAN 看 成 一 台 交 换 机 (只 不 过 它 是 虚拟 交换 
机 ) ， 许 多 问题 就 比较 好 理解 了 ， 因 为 虚拟 交换 机 与 物理 交换 机 具有 
相同 的 基本 属性 。 同 一 物理 交换 机 上 的 不 同 VLAN 之 间 就 像 永 远 不 可 能 
有 物理 连接 、 只 有 逻辑 连接 的 不 同 物理 交换 机 一 样 。 既 然 没 有 物理 连 
接 ， 那 不 同 VLAN 肯 定 是 不 能 直接 相互 通信 的 〈 这 里 仅 指 二 层 通 信 ) ， 
即使 这 些 不 同 VLAN 中 的 成 员 都 处 于 同一 IP 网 段 。 


位 于 同一 VLAN 中 的 端口 成 员 束 相当 于 同一 物理 交换 机 上 的 端口 成 
员 一 样 ， 不 同情 况 仍 都 可 以 按照 物理 交换 机 来 处 理 。 如 同一 VLAN 中 的 
各 成 员 可 以 属于 同一 网 段 ， 也 可 以 属于 不 同 网 段 ， 但 通常 是 把 属于 同 
一 网 段 的 斑点 划分 到 同一 VLAN 中 。 如 采 都 属于 同一 个 网 段 ， 则 肯定 可 
以 相互 通信 ， 束 像 同一 物理 交换 机 上 连接 同一 网 段 的 各 个 主机 用 户 一 
样 ， 但 如 果 同 一 VLAN 中 的 端口 成 员 属于 不 同 网 段 ， 则 相当 于 一 人 台 物 理 


交换 机 上 连接 处 于 不 同 网 段 的 主机 用 户 一 样 ， 这 时 肯定 得 通过 路 由 或 
者 网 天 配置 来 实现 相互 通信 。 


2. 不 同 物理 交换 机 中 的 VLAN 


因为 一 个 VLAN 中 的 端口 成 员 不 是 依据 成 员 的 物理 位 置 来 划分 的 ， 
所 以 通常 是 位 于 网 络 中 的 不 同 交 换 机 上 ， 也 就 是 说 一 个 VLAN 可 以 跨越 
多 人 台 物 理 交 换 机 ， 这 就 是 VLAN 的 中 继 (Trunk) 功能 ， 如 图 6-48 所 
示 。 这 时 我 们 就 不 要 总 按照 物理 交换 机 来 看 待 用 户 的 分 布 了 ， 而 是 要 
从 VLAN 和 角度 来 看 竺 了。 如 在 图 6-48 所 示 中 ， 就 不 要 把 它 当 成 两 台 物 理 
交换 机 ， 而 是 要 把 它 当 成 是 五 台 ， 且 是 两 台 物 理 交 换 机 中 相同 的 两 个 
VLAN 间 有 物理 连接 关系 (就 是 两 台 物 理 交 换 机 间 的 那个 连接 ) 的 物理 
交换 机 。 


图 6-48 不 同 物理 交换 机 上 的 相同 VLAN 


在 不 同 交 换 机 上 可 以 有 相同 的 VLAN， 而 且 这 些 不 同 物理 交换 机 上 
的 相同 VLAN 间 是 相通 的 ， 是 可 以 相互 访问 的 ， 当 然 这 得 在 物理 交换 机 
连接 的 端口 允许 这 些 VLAN 数 据 包 通过 ， 这 就 是 YLAN 中 的 Trunk (中 
继 ) 端口 的 功能 了 。 


在 同一 物理 交换 机 上 的 不 可 能 存在 两 个 相同 的 VLAN， 但 在 不 同 交 
换 机 上 可 以 存在 多 个 相同 的 VLAN (其 实 是 一 台 交 换 机 上 一 个 VLAN 的 
延伸 ) ， 而 默认 情况 下 只 有 相同 VLAN 中 的 成 员 才 可 以 直接 通信 (不 需 
要 路 由 和 桥接 ) ， 所 以 在 同一 物理 交换 机 上 默认 情况 下 不 同 VLAN 间 是 
不 能 直接 通信 有 的， 即使 它们 都 位 于 同一 人 P 网 段 ， 但 位 于 不 同 物理 交换 
机 上 的 相同 VLAN 却 钙 可 以 直接 进行 二 层 通 信 的 ， 只 要 物理 交换 机 间 的 
连接 端口 允许 相应 VLAN 数 据 包 通 过 学 习 即 可 ， 因 为 位 于 不 同 物理 交换 
机 上 的 相同 VLAN 间 的 连接 束 是 物理 交换 机 间 的 物理 连接 。 


经 验 之 谈 这 里 要 区 分 VLAN 中 继 和 中 继 端 口 这 两 个 概念 。VLAN 
中 继 是 指 在 一 台 交 换 机 上 的 VLAN 配 置 可 以 传播 、 复 制 到 的 网 络 中 相连 
的 其 他 交换 机 上 ， 这 就 是 VTP (VLAN 中 继 协 议 ) ; 而 Trunk (中 继 ) 
端口 则 是 指 在 一 个 交换 机 端口 允许 一 个 或 多 个 VLAN 通 信 到 达 网 络 中 相 
连 的 另 一 台 交 换 机 上 相同 的 VLAN 中 。 这 是 两 个 不 同 的 概念 。 


3.VLAN 间 的 互 访 

VLAN 是 二 层 协 议 ，VLAN 的 虚拟 或 者 逻辑 属性 决定 了 这 些 VLAN 
之 间 没 有 物理 二 层 连接 (只 有 逻辑 连接 ) ， 彼 此 独立 ， 相 当 于 一 个 个 
独立 的 二 层 交 换 网 络 。 在 不 可 能 进行 二 层 互 访 的 情况 下 ， 我 们 只 能 通 
过 三 层 来 解决 它们 之 间 的 连接 问题 。 


一 个 独立 交换 网 络 与 另 一 个 独立 交换 网 络 进行 三 层 连接 有 两 种 方 
式 : 一 种 是 通过 网 关 实现 ， 另 一 种 是 通过 路 由 实现 。 在 不 同 VLAN 间 的 
逻辑 连接 也 有 这 两 种 方式 ， 其 中 每 个 VLAN 的 那个 交换 机 虚拟 接口 
(SVI) 就 是 对 应 VLAN 成 员 的 网 关 。 为 每 SVI 配 置 好 IP 地 址 ， 这 个 IP 地 
址 就 是 对 应 VLAN 成 员 的 网 关 IP 地 址 。 这 种 通过 SVI 进 行 的 VLAN 间 成 
员 互 访 的 基本 结构 如 图 6-49 所 示 。 每 个 VLAN 成 员 与 其 他 VLAN 成 员 进 
行 通信 时 都 必须 通过 双方 作为 各 自 VLAN 成 员 网 关 的 SVI。 而 每 个 
VLAN 内 部 的 成 员 端 口 一 般 都 是 二 层 访问 端口 ， 直 接连 接 PC 用 户 。 


VLAN 中 的 端口 成 员 VLAN 中 的 端口 成 员 


图 6-49 不 同 VLAN 间 通过 SVI 进 行 的 逻辑 连接 示意 图 


通过 路 由 方式 来 实现 不 同 VLAN 间 的 连接 可 以 理解 为 在 图 6-49 所 示 
的 两 个 SVI 间 加 了 一 个 提供 路 由 功能 的 设备 ， 可 以 古 路 由 器 (通过 静态 
路 由 或 各 种 路 由 协议 实现 ) ， 也 可 以 是 有 三 层 交 换 模块 的 三 层 交 换 机 
(通过 开启 IP 路 由 功能 实现 ) 。 但 各 个 VLAN 对 外 还 是 以 各 目的 SVI 呈 
现 的 ， 各 VLAN 内 部 还 是 根据 二 层 的 MAC 地 址 进行 寻 址 的 。 当 然 这 是 
在 假设 相同 VLAN 中 的 成 员 痢 是 在 同一 网 段 的 情况 下 。 


如 果 同 一 个 VLAN 中 的 端口 成 员 不 在 同一 个 IP 网 段 ， 则 需要 像 一 台 
物理 交换 机 上 连接 了 多 个 网 段 的 主机 一 样 配置 路 由 或 网 关 来 实现 VLAN 
内 部 各 成 员 的 相互 通信 。 如 果 是 网 关 方式 ， 则 可 以 为 该 VYLAN 的 SVI 分 
配 多 个 对 应 不 同 网 段 的 IP 地 址 ， 这 些 IP 地 址 就 相当 于 多 个 网 关 了 ， 只 
在 对 应 网 段 的 主机 上 配置 指向 SVI 上 的 对 应 IP 地 址 的 网 关 ， 就 可 以 与 同 
一 VLAN 中 其 他 网 段 的 成 员 进 行 通信 了 “。 有 关 VLAN 间 的 路 由 配置 相对 
比较 复杂 ， 在 此 不 做 具体 介绍 了 ， 感 兴趣 的 读者 可 以 参见 笔者 编著 的 

《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 (第 2 版 ) 一 书 。 


6.10.3 IEEE 802.1q 帧 头 部 格式 


既然 VLAN 是 一 个 二 层 协 议 ， 在 交换 机 上 启用 了 它 后 自然 就 会 在 
帧 上 进行 封闭， 添加 VLAN 协 议 头 。 文 持 VLAN 的 交换 机 的 以 太 网 帧 
就 不 再 像 图 6-24 所 示 的 那样 了 ， 其 还 需要 在 以 太 网 帧 Data 字 段 前 中 加 
上 用 于 标记 帧 VLAN 信 息 的 4 个 字段 ( 共 4 字 节 ) IEEE 802.1g VLAN 协 
议 头 ， 如 图 6-50 所 示 。 其 中 Priority、CEFI 和 VLAN ID 这 三 个 字段 统称 为 


TCI (Tag Control Information， 标 签 控制 信息 ) ， 占 2 字 节 。 


TCI ( 2 守节 ) 


6-50 IEEE 802.1q 协 议 头 格式 


说 明 虽然 有 了 VLAN 协 议 ， 但 要 注意 的 是 ， 并 不 是 所 有 设备 都 
文 持 VLAN 协 议 ， 如 我 们 的 主机 、 打 印 机 等 终端 设备 ， 以 及 一 些 傻瓜 
式 交 换 机 都 是 不 文 持 VLAN 协 议 的 ， 所 以 它们 只 能 发 送 和 接收 如 图 6- 
20 所 示 的 不 融 VLAN 标 等 的 以 太 网 帧 。 那 么 这 个 VLAN 标 等 是 在 哪里 
加 上 去 的 呢 ? 它 是 在 文 持 VLAN 协 议 的 交换 机 上 ， 连 接 主 机 和 终端 设 


备 的 二 层 访问 端口 (Access Port) 上 加 上 去 的 。 当 把 一 个 二 层 交 换 机 

端口 添加 到 一 个 VLAN 中 后 就 具有 了 对 应 VLAN 信 息 ， 当 它 接收 到 来 
目 对 应 VLAN 的 主机 发 来 的 帧 时 ， 束 会 在 帧 中 加 上 这 个 VLAN 标 签 ， 

以 标记 该 帧 是 来 自 对 应 的 VLAN。 有 关 交 换 机 的 各 种 端口 类 型 及 收发 

数据 规则 ， 参 见 笔 者 编著 的 《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 
(第 2 版 ) 一 书 。 


图 6-50 中 所 示 的 4 个 字段 的 说 明 如 下 : 


口 TPID: Tag Protocol IDentifier (标签 协议 标识 符 ) 字段 ， 占 2 字 
节 (16 位 ) ， 表 明 这 是 一 个 添加 了 IEEE 802.1q 标 签 的 帧 《区 别 于 未 加 
VLAN 标 记 的 帧 ) ， 值 固定 为 0x8100 (表示 封装 了 IEEE 802.1g VLAN 
协议 ) 。 


口 Priority: User Priority (用 户 优先 级 ) 字段 ， 占 3 位 ， 表 示 0~7 八 
个 优先 级 (数值 越 大 ， 优 先 级 越 高 ， 主 要 用 于 当 交 换 机 阻塞 时 ， 优 
先 发 送 哪个 数据 帧 ， 也 就 是 QoS (服务 质量 ) 的 应 用 ， 是 在 IEEE 
802.1p 规 范 中 被 详细 定义 的 。 


口 CFI: Canonical Format Idicator (标准 格式 指示 器 ) 字段 ， 占 1 
位 ， 用 来 兼容 以 太 网 和 令 牌 环 网 。 用 来 标识 MAC 地 址 在 传输 介质 中 是 
否 以 标准 格式 进行 封装 ， 取 值 为 0 表示 MAC 地 址 以 标准 格式 进行 封 


装 ， 为 1 表示 以 非 标准 格式 封装 ， 默 认 取 值 为 0， 在 以 太 了 网 中 该 值 总 为 
0， 表 示 以 标准 格式 封装 MAC 地 址 。 


经 验 之 谈 在 这 里 要 介绍 一 个 绝 大 多 数 图 书 和 文章 都 没有 介绍 的 
问题 ， 那 就 是 什么 是 标准 格式 MAC 地 址 ， 什 么 是 非 标准 格式 MAC 地 
址 。 其 实 ， 以 太 网 (IEEE 802.3) 和 令 牌 总 线 网 (IEEE 802.4) 在 传输 
介质 中 发 送 MAC 地 址 字 节 是 按 从 低 到 高 的 顺序 〈 也 就 是 我 们 平时 写 
MAC 地 址 格式 中 的 从 右 到 左 的 顺序 ) 进行 的 ， 而 令 牌 环 网 (IEEE 
802.5) 和 IEEE 802.6 标 准 中 MAC 地 址 字 节 在 传输 介绍 中 的 发 送 顺序 则 
相反 ， 是 从 高 到 低 的 顺序 。MAC 地 址 字 节 的 发 送 顺 序 也 对 应 MAC 地 
址 字 节 的 封装 顺序 ， 我 们 把 IEEE 802.3 和 IEEE 802.4 标 准 中 的 MAC 地 
址 封装 顺序 称 为 标准 格式 (canonical form) ， 而 把 IEEE 802.5 和 IEEE 
802.6 标 准 中 的 MAC 地 址 封装 顺序 称 为 非 标 准 格式 (non-canonical 
form) 。 例 如 一 个 MAC 地 址 为 12-34-56-78-9A-BC， 以 标准 格式 发 送 
时 ， 则 它 的 比特 次 序 为 01001000 00101100 01101010 00011110 
01011001 00111101， 但 是 以 非 标准 格式 发 送 时 ， 它 的 比特 次 序 是 
00010010 00110100 01010110 01111000 10011010 10111100 (注意 ， 比 
较 每 个 字 厄 可 以 发 现 ， 它 与 前 面 的 标准 格式 是 次 序 相 反 的 ) 。 


DVLAN ID: VLAN IDentified (VLAN 标 识 ) 字段 ， 占 12 位 ， 指 
明 VLAN 的 ID， 一 共 4096 个 ， 每 个 支持 IEEE 802.1q 协 议 的 交换 机 发 送 
出 来 的 数据 包 都 会 包含 这 个 域 ， 以 指明 自己 属于 哪 一 个 VLAN 。 


6.11 IEEE 802.1w 协 议 


为 了 解决 6.9.3 节 介绍 的 IEEE 802.1d STP 协 议 的 不 足 ， 在 20 世 纪 初 
IEEE 推 出 了 802.1w 标 准 。 它 同样 属于 生成 树 协议 类 型 ， 称 为 快速 生成 
树 协议 (Rapid Spanning Tree Protocol，RSTP) ， 作 为 对 802.1D 标 准 的 
补充 。 


那么 为 什么 在 有 了 IEEE 802.1d 协 议 后 ， 还 要 要 制定 IEEE 802.1w 协 
议 呢 ? 原来 ，IEEE 802.1d 协 议 虽然 解决 了 链 路 闭合 引起 的 死 循环 问 
题 ， 但 是 生成 树 的 收敛 〈 指 重新 设 定 网 络 中 的 交换 机 端口 状态 ) 过 程 
仍 需 比较 长 的 时 间 (30~50s) 。 于 是 IEEE 802.1w 协 议 协议 问世 了 ， 它 
使 得 收敛 过 程 由 原来 的 30~50s 减 少 为 现在 的 1~10s， 因 此 IEEE 802.1w 又 
称快 速生 成 树 协议 (RSTP) 。 对 于 现在 的 网 络 来 说 ， 这 个 速度 足够 快 
了 o 


RSTP 通 过 快速 生成 树 算法 在 交换 网 络 中 阻 断 部 分 见 余 路 径 ， 建 立 
起 无 环 路 的 树 状 网 络 。RSTP 所 采用 的 快速 生成 树 算 法 与 生成 树 算法 一 
样 ， 也 是 一 个 分 布 式 算 法 。RSTP 运 行 在 一 个 桥接 网 络 中 的 所 有 交换 机 
(或 者 交换 机 ) 上 ， 人 负责 为 该 桥接 网 络 计 算出 简单 连通 的 树 形 活跃 拓 
扑 。 计 算 时 也 是 先 选 择 一 个 交换 机 作为 树 根 ( 即 “ 根 交换 机 ”) ， 同 时 
为 所 有 交换 机 的 所 有 端口 指定 角色 。 


RSTP 算 法 基本 和 IEEE 802.1D 标 准 中 定义 的 STP 算 法 基本 一 样 ， 唯 
一 不 同 的 是 RSTP 解 决 了 STP 算 法 对 任何 端口 只 要 从 Blocking (阻塞 ) 状 
态 转换 到 Forwarding (转发 ) 状态 必须 经 过 2 倍 转发 延 时 (包括 由 侦 听 
状态 到 学 习 状 态 的 等 待 时 间 和 由 学 习 状态 到 转发 状态 的 等 待 时间 ) 这 
个 不 足 。 它 利用 点 对 点 连接 ， 针 对 各 种 端口 在 拓扑 中 角色 的 不 同 ， 对 
某 些 端口 实现 了 从 阻塞 状态 直接 转换 到 转发 状态 来 提供 快速 的 生成 树 
收 化 ， 可 以 在 少 于 1 秒 的 时 间 内 重新 配置 生成 树 (在 IEEE 802.1d 的 STP 
生成 树 中 默认 是 50s) 。 


1.RSTP 的 主要 改进 


RSTP 在 STP 基 础 上 做 了 以 下 3 个 重要 改进 (也 是 RSTP 的 主要 优 
势 ) ， 使 得 收敛 速度 快 得 多 (最 快 1s 以 内 ) : 


1) 为 根 端 口 和 指定 端口 设置 了 快速 切换 用 的 替换 端口 (Alternate 
Port) 和 备份 端口 (Backup Port) 两 种 角色 。 当 根 端口 或 指定 端口 失效 
时 ， 准 代 闻 口 或 备份 端口 就 会 无 延 时 地 进入 转发 状态 。 


图 6-51 中 所 有 交换 机 都 运行 RSTP 协 议 ， 交 换 机 1 是 根 交 换 机 ， 图 6- 
51a 中 设 定 交 换 机 3 的 2 号 问 口 为 端口 1 的 备份 决口 ， 备 份 端口 1 中 的 路 径 
信息 ， 这 样 在 闹 口 1 的 路 人 径 信 息 丢 失 后 ， 束 可 以 由 闻 口 2 中 得 到 ， 故 站 
口 2 成 为 端口 1 的 车 代 端 口 。 替 代 端 口 的 作用 是 用 在 古 主 并口 出 现 故 障 
时 ， 人 快速 接 替 主 端口 的 工作 。 图 6-51b 假 设 交 换 机 3 的 端口 1 是 根 端口 ， 


交换 机 2 上 的 端口 2 设置 为 交换 机 3 的 问 口 1 的 玲 代 端口 ， 同 时 进入 阻塞 
状态 。 但 当 交 换 机 3 的 端口 1 所 在 链 路 失效 的 情况 下 ， 区 换 机 2 上 的 端口 
2 就 能 够 立即 进入 转发 状态 ， 且 无 须 等待 2 售 转发 延 时 时 间 。 


交换 机 2 


图 6-51 RSTP 替 代 端 口 的 作用 


2) 在 只 连接 了 两 个 交换 端口 的 点 对 点 链 路 中 ， 指 定 端口 只 需 与 下 
级 交换 机 进行 一 次 握手 就 可 以 无 延 时 地 进入 转发 状态 。 但 如 果 是 连接 
了 3 个 以 上 交换 机 的 共享 链 路 ， 下 级 交换 机 是 不 会 响应 上 级 指定 端口 发 
出 的 握手 请 求 的 ， 其 只 能 像 STP 一 样 等 待 2 倍 转发 延 时 时 间 才 能 进入 转 
发 状态 。 


3) 把 直接 与 终端 (如 PC 机 ) 相连 而 不 是 与 其 他 区 换 机 相连 的 端口 
定义 为 边缘 端口 (Edge Port) “。 边 缘 端口 可 以 直接 进入 转发 状态 ， 不 
需要 任何 延 时 。 但 由 于 交换 机 无 法 知道 端口 是 否 是 直接 与 终端 相连 ， 
所 以 需要 人 工 配置 。 


由 上 可 见 ，RSTP 协 议 相 对 于 STP 协 议 的 改进 主要 体现 在 端口 状态 
上 上。 为 了 支持 这 些 改 进 ，BPDU 的 格式 做 了 一 些 修改 ， 但 RSTP 协 议 仍 
然 向 下 兼容 STP 协 议 ， 可 以 混合 组 网 。 


2.RSTP 的 不 足 


虽然 如 此 ，RSTP 和 STP 一 样 同 属于 单 生 成 树 SST (Single Spanning- 
Tree) ， 所 以 它 仍 具有 以 下 不 足 : 


1) 由 于 整个 交换 网 络 (其 实 就 是 一 个 VLAN 网 络 ) 只 有 一 棵 生成 
树 ， 在 网 络 规 模 比 较 大 的 时 候 会 导致 较 长 的 收敛 时 间 ， 拓 扑 改 变 的 影 
啊 面 也 较 大 。 


2) 在 网 络 结构 不 对 称 的 时 候 ， 单 生成 树 融会 影响 网 络 的 连通 性 。 


3) 当 链 路 被 阻塞 后 将 不 承载 任何 流量 ， 造 成 了 带宽 的 极 大 浪费 ， 
这 在 环 型 城 域 网 的 情况 下 比较 明显 。 


这 些 缺 陷 都 是 单 生 成 树 SST 无 法 克服 的 ， 于 是 支持 VLAN 的 多 生成 
树 (MST) 协议 出 现 了 ， 这 就 是 下 节 要 介绍 的 IEEE 802.1s 协 议 。 


6.12 IEEE 802.1s 协 议 


前 面 介绍 的 IEEE 802.1d STP 和 IEEE 802.1w RSTP 都 是 针对 单一 生 
成 树 实例 《把 整个 交换 网 络 看 成 一 个 生成 树 ) 进行 应 用 的 。Cisco 的 
PVST、PVST+ 和 Rapid-PVST+ 尽 管 属于 多 生成 树 实 例 ， 但 其 是 基于 
VLAN 的 ， 每 个 实例 对 应 一 个 VLAN， 这 样 一 来 不 仅 生 成 树 实例 可 能 会 
非常 多 ， 难 以 管理 ， 还 没有 一 个 容错 机 制 ， 容 易 出 现 单 点 失效 。 这 人 么 
多 生成 树 实例 维护 起 来 比较 困难 ， 而 且 为 每 个 VLAN 每 隔 2s 就 发送 一 个 
BPDU， 交 换 机 也 是 难以 承受 的 。 


为 了 解决 这 一 问题 ，IEEE 工 作 组 又 开发 了 新 的 生成 树 协议 --MSTP 
(Multiple Spanning Tree Procotol， 多 生成 树 协议 ) ， 对 应 的 标准 就 是 
IEEE 802.1s8。MSTP 可 以 对 网 络 中 众多 的 VLAN 进 行 分 组 ， 一 些 VLAN 
分 到 一 个 组 里 ， 男 外 一 些 VLAN 分 到 另外 一 个 组 里 。 这 里 的 组 就 是 后 面 
讲 的 MST (多 生成 树 实例 ) 。 每 个 实例 对 应 一 个 生成 树 ，BPDU 是 只 在 
实例 内 部 进行 发 送 ， 这 样 所 发 送 的 BPDU 数 量 明显 减少 了 ， 减少 了 交换 

机 的 通信 人 负担 。 


说 明 在 IEEE 802.1s MSTP 发 布 以 前 ，Cisco 使 用 的 是 目 己 开发 的 
MISTP (Multiple Instance Spanning Tree Protocol， 多 实例 生成 树 协 
议 ) 。 在 IEEE 正 式 发 布 MSTP 后 ，Cisco 就 直接 采用 IEEE 发 布 的 MSTP 协 
议 ， 原 来 的 MISTP 就 成 了 预 标准 。 


6.12.1 MSTP 简 介 


MSTP 是 IEEE 802.1s 标 准 中 定义 的 一 种 新 型 多 实例 化 生成 树 协议 。 
它 提供 了 快速 收敛 和 在 一 个 VLAN 环 境 下 实现 负载 均衡 双重 优势 。 
MSTP 比 PVST (Per-VLAN Spanning Tree， 每 VLAN 生 成 树 ) 、PVST+ 
(per-VLAN Spanning Tree Plus， 增 强 型 每 VLAN 生 成 树 ) 收敛 更 快 ， 
并 且 与 STP、RSTP 和 PVST+ 生 成 树 架 构 兼 容 。 有 关 PVST 和 PVST+ 生 成 
树 协议 可 参见 笔者 编著 的 《Cisco/H3C 交 换 机 配置 与 管理 完全 手册 》 
(第 2 版 ) 一 书 。 


MSTP 人 允许 通过 VLAN 中 继 来 构建 多 个 生成 树 ， 可 以 组 合 和 关联 和 多 
个 VLAN 到 生成 树 实例 (Spanning Tree Instance，SPI) 。 每 个 实例 可 以 
有 一 个 独立 于 其 他 生成 树 实例 的 拓扑 。 这 种 新 的 架构 为 数据 通信 和 负 
载 均衡 提供 了 多 个 转发 路 径 ， 也 提供 了 网 络 容错 机 制 ， 因 为 一 个 实例 
(也 就 是 一 个 转发 路 径 ) 的 失效 不 会 影响 其 他 实例 。 


与 PVST+ 中 所 有 生成 树 实例 都 是 独立 的 不 一 样 ，MSTP 建 立 、 管 理 
两 种 生成 树 类 型 : 


1) IST (Internal Spanning Tree， 内 部 生成 树 ) : 是 在 MST 区 域 中 
运行 的 生成 树 总 称 。 


IST 是 MST 区 域 中 的 一 个 特殊 生成 树 实例 〈 也 可 以 MST0 表 示 ) ， 
在 一 定 程度 上 代表 了 一 个 MST 区 域 ， 因 为 它 在 一 个 MST 内 部 的 所 有 链 
路 上 都 是 活路 的 ， 专 为 其 他 MST 实 例 提供 拓扑 信息 服务 。 在 一 个 MST 
区 域 中 ，IST 是 不 能 被 删除 的 ， 也 是 自动 存在 的 ， 但 还 可 以 手动 创建 其 
他 MST 实 例 ， 这 些 其 他 MST 实 例 号 只 能 在 1~4094 之 间 ， 通 第 是 以 MSTn 
(n=1~4094) 进行 标识 。 默 认 情 况 下 ， 所 有 VLAN 是 分 配 到 IST 实 例 中 
的 ， 但 在 实际 配置 中 ， 往 往 不 把 任何 VLAN 分 配 到 这 个 实例 中 ， 因 为 
IST 只 用 于 生成 树 BPDU 的 收发 ， 不 用 于 数据 通信 。 


IST 仅 发 送 和 接收 BPDU 的 生成 树 实例 ， 所 有 其 他 生成 树 实例 信息 
包含 在 它 的 MST 记 录 (MSTP Record， 又 称 M 记 录 ) 中 ， 然 后 用 MSTP 
BPDU 进 行 封装 。 因 为 MSTP BPDU 携 带 了 所 有 实例 信息 ， 这 样 在 支持 
多 个 生成 树 实例 时 所 需要 处 理 的 BPDU 数 量 就 会 大 大 减少 。 


在 同一 个 MST 区 域 中 的 所 有 MST 实 例 共享 相同 的 协议 计时 器 ,但 
是 每 个 MST 实 例 有 它们 自己 的 拓扑 参数 ， 如 根 网 桥 ID、 根 路 径 开销 
等 。 上 默认 情况 下 ， 所 有 VLAN 都 是 指派 到 IST 实 例 中 。 但 是 ， 一 个 MST 
实例 与 所 在 区 域 相 关 。 例 如 ， 区 域 A 中 的 MST 实 例 1 与 区 域 B 中 的 MST 
实例 1 是 无 关 的 ， 即 使 区 域 A 和 区 域 B 是 互 连 的 。 


2) CST (Common Spanning Tree， 公 共生 成 树 ) 是 用 来 互联 不 同 
MST 区 域 的 单 生 成 树 实例 。 如 果 把 每 个 MST 区 域 看 做 一 个 设备 ，CST 
就 是 这 些 设备 通过 STP 协 议 、RSTP 协 议 计 算 生 成 的 一 棵 生成 树 。 在 每 


个 MST 区 域 中 计算 出 的 生成 树 都 是 作为 包含 整个 交换 域 的 CST 的 子 树 
出 现 的 。 接 收 到 来 自 其 他 MST 区 域 BPDU 的 交换 机 则 被 称 为 边界 

(Boundary) 交换 机 ， 对 应 的 链 路 称 为 边界 链 路 ， 对 应 的 端口 就 称 为 
边界 端口 ， 如 图 6-52 所 示 。 


图 6-52 MST 区 域 上 的 互联 


3) CIST (Common and Internal Spanning Tree， 公 共和 内 部 生成 
树 ) : 是 一 个 MST 区 域 中 所 有 IST、 连 接 MST 区 域 的 CST (Common 


Spanning Tree， 公 共生 成 树 ) 和 其 他 SST (Single Spanning Trees， 单 生 
成 树 ) 的 集合 。 


由 上 可 知 ， 从 作用 的 范围 来 看 IST 是 最 小 的 ， 仅 属于 一 个 MST 区 域 
内 部 ，CST 次 之 ， 是 MST 区 域 间 的 互联 生成 树 实例 ， 而 CIST 最 大 ， 包 
括 了 IST 和 CST。 它 们 的 作用 范围 天 系 可 以 用 图 6-53 所 示 来 插 述 。 但 要 
知道 的 是 ， 每 个 MST 区 域 中 的 各 实例 生成 树 都 是 作为 CST 的 子 树 。 


图 6-53 IST、MSTn、SST、CST 和 CIST 之 间 的 作用 范围 关系 


除了 以 上 两 种 生成 树 类 型 外 ， 在 理解 MSTP 时 还 涉及 几 个 与 IST、 
CIST 相 关 的 术语 。 


1) CIST 根 (CIST root) : 是 跨越 整个 网 络 的 唯一 实例 一 一 CIST 实 
例 的 根 网 桥 。 除 了 发 送 IST 配 置 BPDU 外 ， 每 个 交换 机 初始 化 时 都 宣告 
目 己 作为 CIST 根 。 交 换 机 连同 IST 配置 BPDU 一 起 传递 CIST 配 置信 息 。 
在 一 个 MST 区 域内 部 的 交换 机 永远 不 会 改变 到 达 CIST 根 的 路 径 开销 ， 
详 见 下 面 要 说 到 的 CIST 外 部 根 路 径 开销 。 


在 边界 端口 上 (如 图 6-52 所 示 ) ， 交 换 机 仅 交 换 它们 的 CIST 
BPDU。 也 就 古 说 ， 在 边界 上 的 交换 机 是 隐藏 MST 区 域 中 的 IST 信 息 
的 ， 但 是 会 传递 CIST 度 量 。 在 边界 链 路 上 通常 会 发 生 RSTP 同 步 进 程 
(因为 启用 MSTP 时 是 会 同时 启用 RSTP 的 ) ， 最 终 在 所 有 区 域 中 ， 具 
有 最 低 BID (网 桥 ID= 优 先 级 值 +MAC 地 址 ) 的 交换 机 被 选举 为 CIST 
根 。 但 要 注意 ， 每 个 区 域 还 会 选举 一 个 本 地 IST 根 的 作为 CIST 区 域 根 。 
这 在 下 面 将 会 说 到 。 


2) CIST 外 部 根 路 径 开 销 (CIST External Root Path Cost) : 是 到 达 
CIST 根 的 开销 。 这 个 开销 在 一 个 MST 区 域 中 是 保持 不 变 的 ， 因 为 MST 
区 域 对 于 CIST 来 说 就 像 一 台 单 一 虚拟 交换 机 。 外 部 根 路 径 开销 仅 计算 
边界 链 路 上 的 开销 ， 而 不 计算 区 域内 部 的 开销 。 本 质 上 ，CIST 外 部 根 
路 径 开销 信息 是 以 隧道 的 方式 穿越 MST 区 域 的 。 


3) CIST 区 域 根 (CIST Regional Root) : 在 Cisco MISTP 预 标准 中 
被 称 为 IST 主 (IST Master) 。 如 果 CST 根 在 区 域 中 ，CIST 区 域 根 就 是 


CIST 根 ; 否则 ，CIST 区 域 根 就 是 到 达 CIST 根 最 近 的 交换 机 。CIST 区 域 
根 是 作为 I ST 的 根 交 换 机 , 。 


包含 CIST 根 的 区 域 ， 同 时 也 会 宣告 该 交换 机 作为 本 地 IST 根 。 但 是 
对 于 不 包含 CIST 根 的 区 域 束 不 是 这 样 了 。 在 不 包含 CIST 根 的 区 域 中 ， 
在 所 有 连接 其 他 MST 区 域 的 边界 交换 机 中 选举 一 个 作为 IST 根 (也 就 古 
CIST 区 域 根 ) 。 这 个 选举 过 程 是 基于 最 低 的 CIST 外 部 根 路 径 开销 的 ， 
不 同 于 前 面 所 说 的 纯粹 依据 BID 的 CIST 根 的 选举 ， 这 种 选举 是 在 一 个 
MST 区 域内 部 进行 。 但 是 ， 如 果 出 现 有 两 台 交 换 机 具有 相同 的 CIST 根 
外 部 路 径 开 销 时 ， 束 会 再 依据 交换 机 的 BID 进 行 再 次 选举 了 。MSTP 会 
阻塞 所 有 标记 为 到 达 CIST 根 的 替代 (alternate) 路 径 的 元 余 边 界 uplinks 
(上 行 链 路 ) 。 


在 一 个 MST 区 域内 ， 交 换 机 建立 常规 IST， 使 用 CIST 区 域 根 作 为 
IST 根 。 但 是 要 注意 ， 这 棵 生成 树 使 用 存储 在 本 地 ISL BPDU 中 的 内 部 
根 路 径 开 销 。 这 种 开销 会 按照 区 域内 部 所 有 链 路 进行 递增 ， 但 是 它 永 
远 不 会 超出 区 域 范围 。 在 区 域 之 间 ， 交 换 机 之 间 仅 交换 CIST 外 部 根 路 
径 开 销 信 息 。 


4) CIST 内 部 根 路 径 开 销 (CIST Internal Root Path Cost) : 是 一 个 
MST 区 域 中 交换 机 到 达 CIST 区 域 根 的 开销 。 这 个 开销 仅 与 IST (实例 
0) 有 关 。 


6.12.2 MST 区 域 及 工作 原理 
对 于 参与 到 MST 实 例 的 交换 机 ， 必 须 考 虑 为 这 些 交换 机 配置 相同 


的 MST 配 置信 息 。 具 有 相同 MST 配 置信 息 的 互联 交换 机 束 组 成 了 一 个 
MST 区 域 。 图 6-54 所 示 的 整 古 一 个 MST 区 域 划分 示例 。 


D 
以 前 的 IEEE802.1 KA 


MST 区 域 2 


图 。6-54 MST 区 域 示例 


MST 配 置 (MST Configure) 控制 每 个 交换 机 属于 哪个 MST 区 域 。 
其 配置 包括 区 域名 称 、 版 本 号 和 MST VLAN 到 实例 的 分 配 上 映射。 你 可 
以 使 用 spanning-tree mst configuration 全 局 配置 模式 命令 来 配置 区 域 中 的 


交换 机 ， 这 样 就 进入 了 MST 配 置 模式 。 在 这 个 模式 下 ， 你 可 以 通过 
instance MST 配 置 模式 命令 回 射 多 个 VLAN 到 一 个 MST 实 例 中 ， 通 过 
name MST 配 置 模式 命令 指定 MST 区 域名 ， 通 过 revision MST 配 置 模式 


命令 设置 修订 号 。 


一 个 区 域 可 有 一 个 或 多 个 具有 相同 MST 配 置 的 成 员 ， 每 个 成 员 都 
必须 具有 处 理 RSTP BPDU 的 能 力 。 一 个 网 络 的 MST 区 域 中 的 成 员 数 是 
没有 限制 的 ， 但 是 每 个 区 域 最 多 只 支持 65 个 生成 树 实例 (是 在 IOS 
12.25XH 及 以 上 版 本 时 ) ， 也 就 是 说 最 多 有 65 个 VLAN 组 。 实 例 可 以 由 
0~4094 范 围 中 的 任 一 数字 标识 。 在 同一 时 刻 ， 仅 可 以 把 一 个 VLAN 分 配 
到 一 个 生成 树 实例 。 


1. 在 MST 区 域内 部 的 工作 原理 


IST 生 成 树 与 MST 区 域 中 所 有 运行 MSTP 的 交换 机 连 授 。 在 IST 收 全 
时 ，IST 的 根 交 换 机 将 成 为 CIST 区 域 根 (在 IEEE 802.1s 标 准 以 前 称 之 为 
IST 主 ) 。 它 是 区 域 中 具有 最 低 网 桥 ID， 到 达 CIST 根 网 桥 路 径 开销 最 小 
的 交换 机 。 注 意 ，CIST 区 域 根 与 CIST 根 是 不 一 样 的 ， 但 如 果 在 网 络 中 
仅 有 一 个 区 域 ， 则 CIST 区 域 根 也 束 是 CIST 根 。 如 果 CIST 根 位 于 区 域 之 
外 ， 则 位 于 区 域 边界 的 MSTP 交 换 机 将 被 选举 为 CIST 区 域 根 。 


当 一 个 MSTP 初 始 化 时 ， 该 MSTP 协 议 将 发 送 BPDU， 要 求 把 自己 
当成 CIST 根 和 CIST 区 域 根 ， 并 且 把 到 达 CIST 根 和 到 达 CIST 区 域 根 的 路 


径 开 销 都 设 为 0。 运 行 MSTP 协 议 的 交换 机 也 会 初始 化 它 的 所 有 MST 实 
例 ， 把 自己 当成 这 些 MST 实 例 的 根 交 换 机 。 如 果 这 台 交 换 机 接收 到 一 
个 比 自己 当前 更 高 级 的 MST 根 信息 (更 低 的 网 桥 ID、 更 低 的 路 径 开销 
等 ) ， 则 它 会 放弃 把 自己 当成 CIST 区 域 根 。 


在 初始 化 过 程 中 ， 一 个 区 域 下 可 以 有 许多 个 子 区 域 (因为 一 开始 
每 个 交换 机 都 把 它 目 己 当 成 区 域 根 ) ， 每 个 于 区 域 都 有 它 目 己 的 CIST 
区 域 根 。 若 交换 机 接收 到 更 高 级 的 I ST 信息， 则 这 些 交换 机 会 离开 原来 
的 子 区 域 ， 而 加 入 到 包含 正确 CIST 区 域 根 的 新 子 区 域 中 。 这 样 ， 子 区 
域 数 会 减少 ， 除 了 包含 正确 CIST 区 域 根 的 那个 子 区 域 。 


正确 情况 下 ， 在 同一 个 MST 区 域 中 的 所 有 交换 机 必须 接受 同一 个 
CIST 区 域 根 ， 所 以 ， 在 区 域 中 的 任何 两 台 交 换 机 如 果 要 收 全 到 同一 个 
CIST 区 域 根 ， 则 仅 需 要 同步 其 在 一 个 MST 实 例 中 的 端口 角色 即 可 。 


2.MST 区 域 间 的 工作 原理 


如 果 网 络 中 有 多 个 区 域 ， 或 者 有 运行 IEEE 802.1d STP 的 交换 机 ,， 
MSTP 需 要 建立 并 维护 CST， 它 包括 网 络 中 所 有 的 MST 区 域 和 所 有 的 
STP 交 换 机 。MST 实 例 与 区 域 边 界 的 IST 实 例 一 起 形成 CST。 


IST 连 接 MST 区 域 中 的 所 有 MSTP 交 换 机 ， 在 整个 交换 域 的 CIST 
中 ，IST 是 以 一 个 子 生 成 树叶 现 的 。 这 个 子 生 成 树 的 根 束 是 CIST 区 域 


根 。 对 于 邻接 的 STP 交 换 机 和 MST 区 域 来 襄 ， 本 地 交换 机 上 的 MST 区 域 
表现 为 一 个 虚拟 交换 机 。 


在 图 6-54 中 包括 了 多 个 MST 区 域 和 一 个 运行 IEEE 802.1d STP 的 交 
换 机 (交换 机 D) 。 区 域 1 的 CIST 区 域 根 也 作为 CIST 根 ， 区 域 2 中 的 
CIST 区 域 根 和 区 域 3 中 的 CIST 区 域 根 分 别 是 各 自 CIST 区 域 中 的 子 生 成 
树 的 根 。 


在 MST 区 域 间 ， 仪 CST 实 例 发 送 和 接收 BPDU，MST 实 例 添加 他 们 
的 生成 树 信息 到 与 邻接 交换 机 交互 的 BPDU 中 ， 并 计算 最 终 的 生成 树 拓 
扑 。 正 因 如 此 ， 与 BPDU 相 关 的 参数 (如 Hello 时 间 、 转 发 和 时间、 最 大 
生存 时 间 和 最 大 跳 数 等 ) 在 CST 实 例 上 配置 ， 这 个 过 程 会 影响 所 有 
MST 实 例 。 与 生成 树 拓扑 相关 的 参数 〈 如 交换 机 优 移 级 、 端 口 VLAN 开 
销 和 端口 VLAN 优 先 级 ) 可 以 同时 在 CST 实 例 和 MST 实 例 上 配置 。 


MSTP 交 换 机 使 用 v3 版 本 的 RSTP BPDU 或 者 IEEE 802.1d STP 
BPDU 与 邻接 的 IEEE 802.1D 交 换 机 通信 。 在 MSTP 交 换 机 之 则 使 用 
MSTP BPDU 进 行 通信 。 


6.13 IEEE 802.1x 协 议 


IEEE 802.1x 标 准 定 义 了 一 个 C/S 模 式 的 访问 控制 和 认证 协议 ， 以 阻 
止 未 授权 客户 端 通过 公共 可 访问 端口 连接 LAN。 认 证 服务 器 在 交换 机 
或 者 LAN 提 供 可 用 服务 之 前 为 每 个 连接 在 交换 机 端口 上 的 客户 端 提供 
认证 。 在 通过 认证 以 前 ，IEEE 802.1x 访 问 控制 仅 允 许 EAPOL 
(Extensible Authentication Protocol overLAN， 基 于 局 域 的 可 扩展 认证 


协议 ) 、CDP (Cisco Discovery Protocol， 思 科 发 现 协 议 ) 、STP 

(Spanning Tree Protocol， 生 成 树 协 议 ) 这 类 控制 通信 通过 端口 到 达 所 
连接 的 客户 端 ， 在 认证 成 功 后 ， 其 他 数据 或 语音 通信 就 都 可 以 在 端口 
此 全 二 


6.13.1 IEEE 802.1x 认 证 设备 角色 


在 整个 IEEE 802.1x 基 于 端口 认证 体系 网 络 中 ， 包 括 了 三 种 基本 角 
色 的 设备 ， 如 图 6-55 所 示 。 


(Authentication Server ) 


Ai (Switch ) 
客户 病 
(Client) 


图 6-55 IEEE 802.1x 基 于 端口 认证 设备 角色 


口 客户 端 (Client) : 是 指 连 接 交 换 机 端口 的 工作 站 主机 ， 是 请 求 
访问 交换 机 和 LAN 服 务 ， 并 从 交换 机 上 得 到 响应 的 工作 站 设备 。 这 个 
工作 站 设备 必须 运行 与 IEEE 802.1x 标 准 兼容 的 客户 端 软件 ， 如 
Windows XP/7 等 系统 。 这 里 的 客户 端 角 色 在 IEEE 802.1x 标 准 中 是 称 为 
尽 求 者 (Supplicant) 


口 认证 服务 器 (Authentication server) : 执行 实际 的 客户 端 认证 工 
作 的 主机 设备 ， 通 常 是 运行 RADIUS 服务 器 程序 的 主机 。 认 证 服务 器 确 
认 客 户 端 身 份 的 合法 性 ， 并 通知 交换 机 对 应 客户 端 是 否 通过 了 认证 ， 
是 否 可 以 访问 局 域 网 和 交换 机 服务 。 因 为 交换 机 担当 中 间 代 理 角 色 ， 
所 以 认证 服务 对 于 客户 端 来 说 是 透明 的 。 目 前 在 Cisco IOS 交 换 机 中 仅 
文 持 RADIUS 服务 器 作为 IEEE 802.1x 认 证 服务 器 。 


口交 换 机 (Switch， 可 以 是 边缘 交换 机 或 无 线 AP) : 对 客户 端 提 
供 基于 客户 端 认 证 状态 的 网 络 访问 控制 。 交 换 机 在 客户 端 和 认证 服务 
妖 之 间 起 一 个 中 间 代 理 角 色 ， 疝 客户 端 请 求 标 识 信息 ， 通 过 认证 服务 
验证 客户 并 标识 信息 ， 同 时 向 客户 端 中 继 转发 认证 服务 器 对 客户 端的 
请 求 响 应 。 交 换 机 包括 RADIUS 客户 端 软件 ， 负 责 EAP 帧 封装 和 解 雪 
装 。 这 里 的 交换 机 角色 在 IEEE 802.1x 标 准 中 是 称 为 认证 者 


(Authenticator) 。 


在 交换 机 接收 到 来 自 客户 端 的 EAPOL 帧 时 ， 中 继 转 发 到 认证 服务 
器 ， 然 后 去 掉 以 太 网 头 部 ， 保 留 EAP 帧 ， 并 以 RADIUS 帧 格式 重新 老 
装 。EAP 帧 在 封装 过 程 中 不 做 修改 ，RADIUS 认 证 服务 器 必须 在 本 地 
(native) 帧 格式 中 支持 EAP。 当 交换 机 收 到 来 自 认 证 服务 器 的 EAPOL 
帧 时 ， 也 会 去 掉 认 证 服务 器 的 头 部 ， 同 时 也 只 保留 EFAP 帧 ， 然 后 重新 
加 上 以 太 网 头 进行 再 封装 ， 然 后 发 送 给 客户 端 。 


6.13.2 IEEE 802.1x 主 机 模式 


IEEE 802.1X 冰 口 上 的 主机 模式 决定 了 在 该 端口 上 连接 了 多 个 客户 端 
时 是 否 允 许多 个 主机 被 认证 ， 以 及 如 何 强制 认证 。 配 置 IEEE 802.1X 端 
口 可 以 使 用 以 下 五 种 模式 中 的 任意 一 种 ， 另 外 ， 其 他 每 种 模式 可 以 修 
改 为 允许 预 认证 开放 访问 模式 : 


口 单 主 机 模式 (Single-Host Mode) : 

口 多 主机 模式 (Multiple-Hosts Mode) : 

口 多 域 认证 模式 (Multidomain Authentication Mode) ; 
口 多 认证 模式 (Multiauthentication Mode) ; 

口 预 认 证 开放 访问 (Preauthentication Open Access) 。 
1. 单 主机 模式 


可 以 配置 IEEE 802.1x 端 口 为 单 主机 模式 或 多 主机 模式 (Single- 
Host Mode) 。 在 单 主 机 模式 中 ， 通 常 是 一 个 交换 机 端口 下 连接 一 台 窗 
户 端 ， 而 不 是 连接 一 个 网 段 (如 图 6-56 所 示 ) ， 且 仅 有 一 个 客户 端 可 以 
连接 在 已 启用 IEEE 802.1x 的 端口 上 。 
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图 6-56 单 主机 模式 IEEE 802.1x 认 证 示例 


在 这 种 模式 中 ， 交 换 机 从 链 路 状态 改变 至 打开 状态 后 ， 通 过 发 送 
一 个 EAPOL 帧 来 检测 客户 端 。 如 果 客 户 端 离开 ， 或 者 接 上 其 他 客户 
端 ， 交 换 机 会 改变 并 口 链 路 状态 为 关闭， 站 口 返回 为 未 授权 状态 ， 不 
允许 新 的 客户 剖 访 问 网 络 。 这 就 是 单 主 机 的 意思 。 


2. 多 主机 模式 


在 多 主机 模式 (Multiple-Hosts Mode) 下 ， 可 以 在 一 个 启用 了 IEEE 
802.1x 的 端口 上 连接 多 个 主机 ， 如 一 个 交换 机 端口 下 面 连接 了 另 一 台 交 
换 机 ， 或 者 WLAN AP。 图 6-57 所 示 为 在 WLAN 中 IEEE 802.1x 基 于 病 口 
的 认证 。 在 这 种 模式 中 ，AP 上 所 有 连接 的 客户 端口 只 要 其 中 一 个 经 过 
了 授权 ， 则 所 有 客户 端 都 可 以 进行 网 络 访问 。 如 果 这 个 端口 没有 经 过 
授权 ， 则 交换 机 拒绝 所 有 连接 客户 问 的 访问 。 在 这 种 拓扑 中 ，WLAN 


AP 负责 为 它 所 连接 的 客户 端 进行 认证 ， 同 时 它 又 作为 交换 机 的 客户 
端 。 
Authentication 
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图 6-57 多 主机 模式 IEEE 802.1x 认 证 示例 


在 启用 了 多 主机 模式 后 ， 可 以 使 用 IEEE 802.1x 认 证 功能 来 验证 端 
口 ， 使 用 端口 安全 功能 管理 所 有 MAC 地 址 的 网 络 访问 ， 包 括 客户 端的 
MAC 地 址 。 


3. 多 域 认 证 模式 


多 域 认 证 (Multidomain Authentication，MDA) 允许 了 电话 和 位 于 
IP 电 话 后 面 的 一 个 主机 单独 使 用 IEEE 802.1x、 旁 路 MAC 地 址 认证 
(MAC authentication bypass，MAB) 或 者 基于 Web 的 认证 〈 仅 限 主 
机 ) 。 多 域 是 指数 据 和 语音 两 个 域 ， 每 个 端口 仅 允 许 两 个 MAC 地 址 的 
设备 访问 。 交 换 机 可 以 把 主机 放 进 数据 YLAN 中 ， 而 把 卫 电 话 放 进 语音 
VLAN 中 ， 即 使 它们 连接 在 同一 个 交换 机 端口 。 数 据 YLAN 和 语音 


LVAN 可 以 在 CLI 中 独立 配置 。 设 备 标 识 为 数据 或 者 语音 设备 依据 的 是 
从 AAA 服务 器 上 接收 到 的 三 商 特殊 属性 (vendor-specific-attributes， 
VSAs) 。 数 据 VLAN 和 语音 VLAN 也 可 以 在 认证 过 程 中 从 AAA 服务 器 
接收 的 VSAs 中 获得 。 


图 6-58 所 示 为 一 个 在 启用 了 IEEE 802.1x 端 口上 连接 的 IP 电 话 后 面 
再 连接 了 单一 主机 的 典型 MDA 应 用 。 因 为 客户 端 不 是 直接 连接 交换 机 
的 ， 所 以 在 客户 端 断 开 连接 时 交换 机 也 不 能 检测 到 端口 链 路 的 丢失 。 
为 了 阻止 其 他 设备 使 用 原 客 户 端 已 建立 的 认证 属性 非法 连接 在 这 个 已 
启用 IEEE 802.1x 端 口上 ，Cisco IP 电 话 会 发 送 一 个 CDP 主 机 已 存在 的 类 
型 -长 度 - 值 (TLV) 包 通 知 交换 机 连接 客户 端的 端口 链 路 状态 已 发 生 改 
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图 6-58 多 域 认 证 模式 IEEE 802.1x 认 证 示例 


4. 多 认证 模式 


多 认证 模式 (Multiauthentication Mode) 允许 一 个 语音 VLAN 中 的 
客户 端 和 多 个 数据 VLAN 中 的 客户 端 得 到 认证 。 当 一 个 集 线 超 或 者 AP 


连接 到 一 个 启用 了 IEEE 802.1x 端 口 时 ， 多 认证 模式 通过 为 每 个 客户 端 
分 别 请 求 认证 ， 为 多 个 主机 提供 安全 认证 。 对 于 不 兼容 IEEEF 802.1x 的 
设备 ， 可 以 使 用 MAB ( 旁 路 MAC 地 址 认证 ) 或 者 基于 Web 认 证 方式 作 
为 个 别 主 机 的 认证 方法 ， 人 允许 在 一 个 端口 上 为 不 同 主机 提供 不 同 的 认 
证 记忆 

多 认证 模式 通过 分 配 请 求 认证 的 设备 到 数据 或 者 语音 VLAN 中 来 支 
持 语 首 VLAN 中 的 MDA (多 域 认证 ) 功能 。 当 一 个 端口 处 于 多 认证 模 
式 时 ， 来 宾 VLAN 和 认证 失败 的 VLAN 将 不 再 在 数据 设备 上 激活 。 


5. 预 认证 开放 访问 


以 上 四 种 认证 模式 中 的 任何 一 种 都 可 以 通过 额外 配置 来 允许 一 个 
设备 在 通过 认证 前 获取 网 络 访问 权限 。 这 种 预 认证 开放 访问 
(preauthentication open access) 功能 在 像 预 启动 执行 环境 (Pre-boot 
eXecution Environment，PXE， 如 远程 启动 设备 ) 应 用 中 非常 有 用 ， 
为 这 类 设备 必须 在 启动 时 访问 网 络 ， 从 网 络 上 下 载 包括 认 证 客户 端的 
可 局 动 映 象 等 文件 。 


在 配置 了 主机 模式 后 可 通过 authentication open 命 令 启 用 预 认证 开放 
访问 功能 ， 作 为 配置 的 主机 认证 模式 扩展 。 例 如 ， 如 有 果 在 单 主机 模式 
下 局 用 预 认证 开放 访问 功能 ， 则 端口 上 仅 允 许 一 个 MAC 地 址 访问 。 当 
局 用 预 认证 开放 功能 时 ， 端 口上 的 初始 化 通信 仅 受 在 端口 上 配置 的 其 


他 不 依赖 于 IEEE 802.1x 的 访问 控制 方法 限制 。 如 果 在 端口 上 没有 配置 
其 他 访问 控制 方法 ， 则 客户 端 设 备 可 以 全 面 访问 所 配置 的 VLAN。 


6.13.3 IEEE 802.1x 认 证 流程 


交换 机 端口 状态 决定 了 所 连接 的 客户 端 是 否 被 允许 访问 网 络 。 端 
口 最 初 的 状态 是 未 授权 状态 ， 此 时 端口 除了 IEEE 802.1x 协 议 包 外 不 能 
接收 和 发 送 任何 包 。 在 端口 通过 IEEE 802.1x 认 证 后 ， 则 该 端口 转换 成 
授权 状态 ， 人 允许 所 有 通信 通过 。 


如 果 一 个 不 兼容 IEEE 802.1x 的 客户 问 连 接 到 一 个 未 授权 的 交换 机 
端口 上 ， 则 交换 机 会 向 该 客户 发 送 请 求 标识 。 但 是 ， 在 此 时 该 客户 不 
会 响应 交换 机 的 这 个 请 求 ， 继 续 保 持 未 授权 状态 ， 该 客户 端 也 不 允许 
访问 网 络 。 如 果 在 该 端口 上 配置 了 一 个 来 宾 VLAN， 则 该 端口 以 未 授权 
状态 被 置 于 这 个 来 宾 VLAN 中 。 


相反 ， 如 果 一 个 支持 IEEE 802.1x 的 客户 端 连接 到 一 个 没有 运行 
IEEE 802.1x 协 议 的 交换 机 端口 中 上 ， 客 户 端 通过 发 送 EAPOL-start 帆 初 
台 化 认证 过 程 。 但 是 ， 此 时 ， 客 户 端 不 会 收 到 交换 机 的 啊 应 ， 在 多 次 
发 送 请 求 仍 没收 到 交换 机 的 响应 后 ， 客 户 端 就 认为 它 所 连接 的 端口 是 
处 于 授权 状态 的 ， 正 常 发 送 数 据 。 


1. 端 口 状态 


在 交换 机 设备 中 可 以 配置 以 下 端口 状态 : 


口 force-authorized: 强制 授权 ， 禁 止 IEEE 802.1x 认 证 ， 使 端口 处 于 
不 需要 IEEE 802.1x 认 证 消息 交换 的 授权 状态 。 该 端口 无 须 经 过 IEEE 
802.1x 认 证 就 可 正常 接收 和 发 送 客 户 端 的 通信 。 这 是 默认 设置 。 


口 force-unauthorized: 强制 非 授 权 ， 使 端口 处 于 未 授权 状态 ， 忽 略 
客户 端的 所 有 认证 请 求 。 交 换 机 不 能 为 连接 在 这 些 端口 上 的 客户 端 提 
供认 证 服务 。 


Dauto: 允许 进行 IEEE 802.1x 认 证 ， 使 端口 最 开始 为 未 授权 状态 ， 
仅 允 许 接收 和 发 送 EAPOL 帧 。 当 对 应 端口 所 在 链 路 状态 由 关闭 到 打开 
时 ， 或 者 当 接收 到 一 个 EAPOL-start 帧 时 开始 IEEE 802.1x 认 证 。 交 换 机 
向 客户 端 请 求 标 识 ， 并 开始 在 客户 端 和 认证 服务 咱 之 间 中 继 认 证 消 
息 。 交 换 机 可 以 使 用 客户 端的 MAC 地 址 来 唯一 标识 连接 网 络 的 每 个 客 
尸 问 。 


如 有 条 客户 端 成 功 通 过 认证 ， 则 其 所 连接 的 端口 改变 为 授权 状态 ， 
来 目 该 客户 端的 所 有 通信 均 可 通过 此 端口 ， 如 果 认 证 失败 ， 则 此 端口 
仍 保持 在 未 授权 状态 ， 但 是 仍 将 尝试 认证 。 如 果 认 证 服务 器 不 可 达 ， 
则 交换 机 可 以 重 传 客 户 端 的 认证 请 求 ， 如 打 在 指定 次 效 重 传 后 仍 不 能 
接收 到 来 自 认 证 服务 器 的 响应 ， 则 认证 失败 ， 对 应 的 客户 端 不 允许 访 
问 网 络 。 


如 条 对 应 端口 的 链 路 状态 由 打开 变 为 天 财 ， 或 者 咒 口上 接收 到 一 
个 帧 ， 则 此 器 口 恢复 为 未 授权 状态 。 


2.IEEE 802.1x 认 证 流程 


若 启 用 IEEE 802.1x 基 于 端口 认证 ， 并 有 旦 客户 端 支持 IEEE 802.1x 客 
户 端 ， 则 将 发 生 以 下 认证 事件 : 


口 如 有 果 客 户 端 标识 是 有 效 购 ， 并 且 成 功 通过 IEEE 802.1x 认 证 ， 则 
交换 机 人 允许 客户 端 访 问 网 络 。 


口 如 果 在 交换 机 等 竺 来自 客户 端 或 者 认证 服务 器 的 EAPOL 消 息 交 
换 过 程 中 超时 ， 并 且 启 用 了 MAC 地 址 认证 旁 路 特性 (MAC 
authentication bypass， 也 就 是 不 进行 IEEE 802.1x 认 证 ， 直 接 采 用 MAC 
地 址 认证 ， 这 对 一 些 不 能 安装 IEEE 802.1x 兼 容 软 件 的 设备 的 认证 非常 
必要 ， 如 打印 机 和 特殊 的 终端 ， 交 换 机 可 以 使 用 客户 端 MAC 进 行 认 
证 。 如 果 客 户 端 MAC 地 址 是 有 效 的 ， 且 通过 了 MAC 地 址 认证 ， 则 交换 
机 允许 客户 端 访问 网 络 ;， 如果 客户 端 MAC 地 址 是 无 效 的 ，MAC 地 址 认 
证 失败 ， 则 交换 机 分 配 这 个 客户 端 到 来 宾 VLAN (guest VLAN， 在 已 
配置 了 来 宾 VLAN 的 前 提 下 ) ， 仅 提供 有 限 的 服务 。 


口 如 果 交 换 机 从 兼容 IEEE 802.1x 的 客户 端 获 得 一 个 无 效 的 客户 端 
身份 标识 ， 并 且 指 定 了 一 个 受 限 的 VLAN (如 来 宾 VLAN) ， 则 交换 机 
可 以 分 配 该 客户 端 到 受 限 YLAN 中 ， 仅 提供 有 限 服务 。 


口 如 果 RADIUS 认 证 服务 器 不 可 用 (关闭 了 ) ,但 启用 了 临界 认证 
(critical authentication， 即 inaccessible authentication bypass， 或 者 称 为 
AAA 失效 策略 ) 特性 ， 则 交换 机 通过 把 端口 置 于 RADIUS 服务 器 上 配 
置 的 或 者 用 户 指 定 的 访问 YLAN 的 临界 认证 状态 来 允许 客户 端 访问 网 
络 。 


图 6-59 显 示 了 IEEE 802.1x 基 于 端口 认证 流程 ， 当 发 生 以 下 情形 
时 ， 交 换 机 会 重新 认证 客户 端的 。 


交换 机 获取 
EAPOL 消息 ， 

并 开始 EAPOL 
消息 交换 | 


开始 IEEE 802.1x 


eas 一 人 IMAC 地 址 党 特性 | 
es 六 的 安 合法 的 客 | 非法 的 客 
非法 的 客户 合法 的 客户 户 端 MAC | 户 端 MAC 
端 身份 标识 端 身份 标识 地 址 身份 | 地 址 身份 
示 识 标识 
分 配 端 口 到 分 配 端 口 到 分 配 端口 到 ”| 分 配 端口 到 一 个 
受 限 VLAN 中 一 个 VLAN 中 一 个 VLAN 中 来 宾 VLAN 中 
结束 结束 结束 结束 
所 有 认证 服务 器 所 有 认证 服务 器 
都 已 关闭 都 已 关闭 
使 用 临界 认证 (critical 


authentication ) 分 配 临 
界 端口 到 一 个 VLAN 中 


图 6-59 IEEE 802.1x 认 证 流程 


(1) 启用 了 周期 性 重 认 证 (Periodic re-authentication) 功能 ， 并 且 
重 认证 计时 姻 已 过 期 。 


可 以 使 用 一 个 指定 的 值 ， 或 者 RADIUS 服务 器 上 的 配置 值 来 配置 重 
认证 计时 器 。 在 使 用 配置 的 RADIUS 服务 器 进行 IEEE 802.1x 认 证 后 ， 


交换 机 使 用 基于 会 话 超时 (Session-Timeout) RADIUS 属性 (属性 27) 
和 终止 行为 〈Termination-Action) RADIUS 属性 (属性 29) 的 计时 器 


会 话 超时 属性 指定 了 多 长 时 间 后 进行 重 认证 ， 而 终止 行为 属性 指 
定 在 重 认 证 过 程 中 将 发 生 的 行为 。 这 个 行为 包括 两 种 : 初始 化 
(Initialize) 和 重 认证 (ReAuthenticate) 。 当 设置 为 初始 化 行为 时 (此 
时 默认 属性 值 为 DEFAULT) ，IEEE 802.1x 会 话 终止 ， 在 重 认证 过 程 中 
断 开 连接 ; 当 设 置 为 重 认证 属性 时 〈 此 时 属性 值 为 RADIUS- 
Request) ， 在 重 认证 过 程 中 IEEE 802.1x 会 话 不 受 影响 。 


(2) 通过 dot1x re-authenticate interface interface-id 特 权 模 式 命令 对 


客户 着 进 行 重 认证 。 


有 关 IEEE 802.1x 协 议 的 详细 工作 原理 及 配置 请 参见 笔者 编著 的 
《Cisco/H3C 交 换 机 高 级 配置 与 管理 技术 手册 》 一 书 。 


6.14 主要 WLAN 标 准 与 技术 


近年 来 ， 在 局 域 网 技术 方面 ， 最 引 人 有 瞩目 的 应 该 非 WLAN (无 线 
局 域 网 ) 技术 莫 属 。 可 以 说 是 一 年 一 个 跨越 ， 短 短 10 多 年 ， 从 最 初 的 
2Mbps 速 率 到 了 今天 的 600Mbps， 现 在 千 兆 速率 的 WLAN 标 准 也 在 开 
发 ， 并 即将 发 布 之 中 。 在 其 中 不 仅 诞生 了 各 种 不 同 接 入 速率 的 WLAN 
接 入 规范 ， 也 诞生 了 许多 相对 应 的 新 技术 。 本 市 就 要 对 这 些 WLAN 接 
入 标准 和 相关 主要 技术 作 一 个 全 面 的 介绍 。 


就 像 以 太 网 中 有 许多 以 太 网 接 入 规范 〈 在 IEEE 802.3 标 准 中 ) 一 
样 ，WLAN 也 有 许多 对 应 的 接 入 规范 ， 它 们 均 在 IEEE 802.11 标 准 之 
中 。 目 前 该 系列 包含 以 下 四 种 WLAN 接 入 规范 包括 : IEEE 802.11b、 
IEEE 802.11a、IEEEE 802.11g 和 IEEE 802.1ln， 目 前 还 有 两 种 更 高 接 入 
速率 的 WLAN 接 入 规范 正在 研发 之 中 ， 那 就 是 IEEE 802.11ac 和 IEEE 
802.11ad， 它 们 的 基本 特性 比较 如 图 6-60 所 示 。 
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图 6-60 IEEE802.11 系 列 接 入 规范 基本 特性 比较 


WLAN 采 用 的 是 IEEE 802.11 系 列 规范 ， 它 也 是 由 IEEE 802 标 准 委 
员 会 制定 的 。1990 年 IEEE 802 标 准 化 委员 会 成 YIEEE 802.11 WLAN 标 
准 工 作 组 ， 最 初 的 无 线 局 域 网 标准 是 IEEE 802.11 于 1997 年 正式 发 布 
的 ， 该 标准 定义 了 物理 层 和 介质 访问 控制 (MAC) 规范 。 物 理 层 定义 
了 数据 传输 的 信号 特征 和 调制 ， 工 作 在 2.4000~2.4835GHz 频 段 。 这 一 
最 初 的 无 线 局 域 网 标准 主要 用 于 难于 布线 的 环境 或 移动 环境 中 计算 机 
的 无 线 接 入 ， 由 于 传输 速率 最 高 只 能 达到 2Mbps， 所 以 业务 主要 被 用 于 
数据 的 存 取 。 但 随 着 无 线 局 域 网 应 用 的 不 断 深入 ， 人 们 越 来 越 认识 
到 ，2Mbps 的 连接 速率 远 远 不 能 满足 实际 应 用 需求 ， 于 是 IEEE 802 标 准 
委员 会 推出 了 一 系列 高 接 入 速率 的 新 WLAN 规 范 。 


6.14.1 IEEE 802.11b 规 范 主要 特性 


在 WLAN 的 发 展 历史 中 ， 真 正 具有 实用 无 线 连接 的 WLAN 标 准 还 
是 1999 年 9 月 正式 发 布 的 IEEE 802.11b。 该 规范 的 主要 特性 如 下 : 


(1) 工作 频段 


IEEE 802.11lb 规 范 工作 在 免费 的 2.4GHz 频 段 ， 室 内 有 效 传输 距离 为 
35m， 罕 外 有 效 传输 距离 为 140m 。 


(2) 传输 速率 


IEEE 802.11b 规 范 的 最 高 传输 速率 为 11Mbps， 还 可 根据 实际 网 络 环 
境 调整 为 IMbps、2Mbps 和 5.5Mbps (相对 现在 几 百 兆 速率 的 WLAN 来 
说 ， 它 早已 被 淘汰 了 ) 。 


(3) 调制 方法 


IEEE 802.11b 规 范 可 根据 不 同 接 入 速率 采用 不 同 的 调制 技术 : 传输 
速率 为 1IMbps 和 2Mbps 时 ， 采 用 原来 IEEE 802.11 规 范 中 的 DSSS (Direct 
Sequence Spread Spectrum ， 直 接 序 列 扩展 ) 、DBPSK (Differential 
Binary Phase Shift Keying， 差 分 二 相位 键 控 ) 、DQPSK (Differential 
Quadrature Phase Shift Keying， 差 分 四 相位 键 控 ) 等 数字 调制 方法 ， 传 
输 速 率 为 5.5Mbps 和 11Mbps 时 ， 采 用 CCK (Complementary Code 
Keying， 互 补 编码 键 探 ) 调 制 方法 。 


说 明 DSSS 是 先 将 信号 源 与 一 定 的 PN (Pseudo Noise， 伪 噪声 ) 
码 进行 混合 ， 然 后 通过 DBPSK、DQPSK 相 位 键 控 技术 将 原来 信号 中 的 
0 或 1 比特 用 11 个 chips 的 巴克 序列 (Barker 人 : 
{+1，-1，+1，+1，-1，+1，+1，+1，-1，-1，-1} 进 行 替代 ， 扩 展 频 

， 使 得 原来 较 高 功率 、 较 第 频带 的 频率 变 成 具有 较 宽 频带 的 低 功率 
频率 。 简 单 来 说 ，DSSS 利 用 高 频率 的 信号 ， 通 过 各 个 调 变 技术 进行 扩 
展 频 ， 将 发 送 端的 频谱 信号 频带 展 宽 ， 而 在 接收 端 用 相同 的 展 频 技术 
去 进行 译 码 ， 把 展 频 后 的 信号 还 原 成 原始 的 信息 。DSSS 具 有 抗 干扰 能 


力 强 、 抗 多 径 干 扰 能 力 强 、 对 其 他 电台 干扰 小 、 抗 截获 能 力 强 、 可 以 
同 频 工作 、 便 于 实现 多 址 通信 等 优点 。 


(4) 信道 划分 


IEEE 802.11b 规 范 全 球 使 用 的 是 同一 无 线 电 模 型 ， 共 有 11 个 信道 
个 信道 带宽 为 22MHz， 但 相 邻 信道 间 只 有 5MHz 带 宽 不 重合 (也 就 是 
会 重合 17MHz 和 带宽) ， 如 图 6-61 所 示 。 因 为 每 两 个 相 邻 信道 都 会 有 大 
部 分 的 频段 重 奢 ， 所 以 在 IEEE 802.11b 规 范 的 整个 频段 中 ， 真 正 完全 不 

重要 的 信道 最 多 只 有 3 个 ， 如 图 6-62 所 示 。 这 些 不 重 肥 的 信道 有 五 种 组 
合 ， 那 就 是 ，1、6 和 11 号 信道 ， 2 和 7 号 信道 ，3 和 8 号 信道 ，4 和 9 号 信 
道 ， 以 及 5 和 10 号 信道 。 每 个 区 域 WLAN 网 络 只 能 选择 一 组 ， 且 推荐 使 
用 1、6 和 11 这 组 信道 ， 这 样 就 可 以 在 同一 个 区 域 WLAN 网 络 中 部 署 3 台 
AP 了 “。 为 保证 这 部 分 区 域 所 使 用 的 信号 信道 不 能 互相 覆盖 ， 各 AP 要 使 
用 不 同 的 信道 ， 最 好 选择 完全 不 重合 的 一 组 信道 


802.11b 规范 信道 分 布 


图 6-61 IEEE 802.11b 信 道 分 布 
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图 6-62 IEEE 802.11b 规 范 信 道 划 分 及 
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IEEE 802.11b 和 IEEE 802.11g 规 范 中 的 信道 划分 如 表 6-10 所 示 。 


表 6-10 IEEE 802.11b 和 1EEE 802.11g 规范 中 的 信道 划分 


信道 ID 信道 中 心 频率 /GHz IEEE 802.11g 信道 中 心 频 率 /GHz 
1 2.412 
2 2.417 
3 2.422 
4 2.427 
5 2.432 
6 2.437 
7 2.442 
8 2.447 
9 2.452 
10 2.457 法 国 仅 允许 使 用 的 频道 ) 


2.462( 法 国 仅 允许 使 用 的 频道 ) 
2.467 (法国 仅 允许 使 用 的 频道 ) 
2.472 法国 仅 允许 使 用 的 频道 ) 


(5) 主要 安全 技术 


IEEE 802.11b 规 范 主 要 采用 的 安全 技术 包括 : SSID (Service Set 
Identifier， 服 务 集 标识 符 ) 和 WEP (Wired Equivalent Privacy， 有 线 等 
效 保 密 ) 链 路 加 密 。 在 2003 年 以 后 生产 的 IEEE 802.11b 规 范 的 WLAN 一 
般 还 支持 WPA 和 IEEE 80.1x 安 全 技术 ， 但 这 通常 是 在 同时 文 持 IEEE 
802.11b 和 IEEE 802.11g 两 种 规范 的 设备 中 提供 ， 单 独 的 IEEE 802.11b 设 
备 不 支持 。 


说 明 ”SSID 是 一 个 无 线 局 域 网 的 名 称 。 同 一 网 络 中 的 所 有 无 线 设 
备 必 须 具 有 相同 的 SSID 才 能 实现 相互 通信 。 无 线 客 户 闪 的 SSID 可 以 通 
过 输入 名 称 到 网 络 设置 进行 手动 设置 ， 或 者 目 动 设 置 为 不 指定 或 至 。 


网 络 管理 员 通 常 使 用 公开 的 SSID ， 在 AP 中 设置 并 广播 给 所 有 在 网 络 范 
围 内 的 无 线 设 备 。 但 现在 新 的 AP 默认 是 禁用 了 SSID 自 动 广播 这 个 功能 
的 ， 以 提高 网 络 的 安全 性 。 另 外 ， 因 为 WLAN 有 是 通过 电波 进行 数据 传 
输 的 ， 存 在 电波 洪 漏 导致 数据 被 截 听 的 风险 ， 所 以 采用 WEP 链 路 加 密 
保护 措施 。 它 是 源 目 于 RSA 数 据 加 密 技 术 ， 提 供 了 40 位 和 128 位 长 度 的 
密 钥 机 制 ， 但 它 是 一 个 对 称 加 /解密 方案 ， 在 数据 的 加 密 和 解密 过 程 中 
使 用 相同 的 密 钥 和 算法 ， 存 在 较 大 安全 风险 。 


WPA (Wi-Fi Protected Access，Wi-Fi 受 保护 访问 ) 作为 IEEE 
802.11i 标 准 的 子 集 ， 包 含 了 认证 、 加 密 和 数据 完整 性 校 验 三 个 部 分 ， 
是 一 个 完整 的 安全 方案 。 其 核心 是 IEEE 802.1x 和 TKIP (Temporal Key 


Integrity Protocol， 临 时 密 钥 完整 性 协议 ) 。 


WPA 走 一 种 继承 了 WEP 基 本 原理 而 又 解决 了 WEP 缺 点 的 新 技术 ， 
使 用 128 位 密 钥 。 由 于 加 强 了 生成 密 钥 的 算法 ， 因 此 即便 收集 到 分 组 信 
轧 并 对 其 进行 解析 ， 也 几乎 无 法 计算 出 通用 密 钥 。 其 原理 为 根据 通用 
密 钥 ， 配 合 表 示 计 算 机 MAC 地 址 和 分 组 信息 顺序 号 的 编号 ， 分 别 为 每 
个 分 组 信息 生成 不 同 的 密 钥 ， 然 后 与 WEP 一 样 将 此 密 钥 用 于 RC4 加 密 
处 理 。 通 过 这 种 处 理 ， 所 有 客户 端的 分 组 信息 所 交换 的 数据 将 由 各 个 
不 相同 的 密 钥 加 密 而 成 。 无 论 收集 到 多 少 这 样 的 数据 ， 要 想 破解 出 原 
始 的 通用 密 钥 几 乎 是 不 可 能 的 。WPA 还 追加 了 防止 数据 中 途 被 自 改 的 
功能 和 认证 功能 。 由 于 具备 这 些 功能 ， 此 前 WEP 中 备 受 指责 的 缺点 得 


以 全 部 解决 。WPA 不 仅 是 一 种 比 WEP 更 为 强大 的 加 密 方法 ， 而 且 有 更 
为 丰富 的 内 洱 。 


IEEE 802.1x 是 用 于 WLAN 的 一 种 增强 性 网 络 安全 解决 方案 ， 就 古 
用 来 控制 无 线 工 作 站 对 AP 的 访问 。 如 果 认 证 通过 ， 则 AP 为 对 应 工作 站 
打开 逻辑 端口 ， 否 则 不 允许 用 户 上 网 。IEEE 802.1x 要 求 无 线 工 作 站 安 
装 802.1x 客 户 端 软件 ，AP 要 内 舱 802.1X 认 证 代理 ， 同 时 它 还 作为 Radius 
客户 病 ， 将 用 户 的 认证 信息 转发 给 Radius 服 务 右 。IEEE 802.1x 除 提供 
端口 访问 控制 能 力 之 外 ， 还 提供 基于 用 户 的 认证 系统 及 计 费 ， 特 别 适 
合 于 公共 无 线 接 入 解决 方案 。 


6.14.2 IEEE 802.11a 规 范 主要 特性 


虽然 IEEE 802.11b 规 范 的 11Mbps 传 输 速 率 比 起 规 艺 的 IEEE 802.11 
的 2Mbps 来 说 有 了 几 倍 的 提高 ， 但 这 也 只 是 理论 数值 ， 在 实际 应 用 环境 
中 的 有 效 速率 还 不 到 理论 值 的 一 半 。 为 了 继续 提高 传输 速率 ，IEEE 
802 工 作 小 组 继续 了 下 一 个 规范 的 开发 ， 那 就 是 2001 年 的 发 布 的 IEEE 


802.11a。 


经 验 之 谈 在 这 里 要 说 明 的 一 件 事 就 是 ， 为 什么 最 先 推 出 的 规范 
命名 为 IEEE 802.11b， 而 后 来 推出 的 规范 反而 是 IEEE 802.11a。 那 是 因 
为 ， 这 两 个 规 匈 是 分 属于 两 个 不 同 的 小 组 。 事 实 上 IEEE 802.11a 规 范 与 
IEEE 802.11b 的 研制 工作 是 同时 开始 的 ， 只 是 在 后 来 正式 完成 、 发 布 
中 ，IEEE 802.11b 规 范 却 走 在 了 前 面 ， 所 以 最 和 完 发 布 的 是 IEEE 
802.11b， 而 不 是 IEEE 802.11a。 还 有 一 点 ， 那 就 是 IEEE 802.11a 规 范本 
来 要 先 于 IEEE 802.11b 发 布 ， 所 以 其 速度 原先 的 设想 不 是 54Mbps， 只 
是 IEEE 802.11b 发 布 了 11Mbps 的 规范 ， 所 以 IEEE 802.11a 规 范 的 连接 速 
率 就 不 可 能 再 低 于 或 者 接近 11Mbps， 只 能 超过 。 


IEEE 802.11a 规 范 的 主要 特性 如 下 : 


(1) 工作 频段 


IEEE 802.11a 规 范 工作 频段 为 商用 的 5GHz 频 段 (不 是 采用 IEEE 
802.11b 规 范 中 的 2.4GHz 免 费 频段 ， 所 以 不 与 IEEE 802.11b 设 备 兼 
容 ) ， 室 内 有 效 传输 距离 35m， 室 外 有 效 传输 距离 120m 。 


(2) 传输 速率 


IEEE 802.11a 规 范 的 最 高 数据 传输 速率 为 54Mbps， 根 据 实 际 网 络 环 
还 可 调整 为 (Mbps、9Mbps、12Mbps、18Mbps、36Mbps、 
48Mbps。 


IEEE 802.11a 规 范 的 每 个 信道 的 带宽 有 两 种 选择 : 20MHz 或 
40MHz， 如 果 为 20MHz 带 宽 ， 则 共有 24 个 不 相互 重 且 的 信道 ， 如 果 是 
40MHz 带 宽 ， 则 共有 12 个 不 相互 重 县 的 信道 。 表 6-11 列 出 了 可 用 的 24 个 
信道 及 所 适用 的 环境 。 


表 6-11 1IEEE 802.11a 规范 中 的 信道 划分 


信道 ID 信道 中 心 频率 /MHz 适用 环境 


149 EE 要 用 于 室外 
153 要 用 于 室外 
157 主要 用 于 室外 
165 主要 用 于 室外 


(4) 调制 方法 


IEEE 802.11a 规 范 采 用 52 个 OFDM (Orthogonal Frequency Division 
Multiplexing， 正 交 频 分 复 用 ) 调制 扩 频 技术 ， 可 提高 信道 的 利用 率 。 
在 52 个 OFDM 中 的 52 个 载波 中 ，48 个 用 于 传输 数据 ，4 个 是 引 示 副 载波 

(pilot carrier， 就 是 载波 里 面 没 有 携 囊 任何 数据 ， 每 一 个 带宽 为 


0.3125MHz (20MHz/64) ， 可 以 应 用 BPSK 《二 相 移 相 键 控 ) 、QPSK 

(四 相 移 相 键 控 ) 、16-QAM 或 者 64-QAM 调 制 技术 。OFDM 技 术 将 信 
道 分 成 若干 正 交 子 信道 ， 将 高 速 数据 信 号 转换 成 并 行 的 低速 子 数据 
流 ， 再 调制 到 每 个 子 信道 上 进行 传输 。 正 交 信 号 可 以 通过 在 接收 端 采 
用 相关 技术 来 分 开 ， 这 样 可 以 减少 子 信 和 道 之 间 的 相互 干扰 。 


(5) 主要 安全 技术 


IEEE 802.11a 规 范 在 安全 方面 一 开始 也 主要 使 用 WEP 加 密 拉 术 和 
SSID。2003 年 以 后 生产 的 IEEE 802.11a 规 范 的 WLAN 一 般 还 支持 WPA 和 
IEEE 80.1x 安 全 技术 ， 但 这 通常 是 在 同时 支持 IEEE 802.11a 和 IEEE 
802.11g 两 种 规 施 的 设备 中 提供 ， 单 独 的 IEEE 802.11a 设 备 不 文 持 。 


6.14.3 IEEE 802.11g 规 范 主要 特性 


虽然 IEEE 802.11a 规 范 的 速度 已 非常 快 了 ， 但 由 于 IEEE 802.11b 与 
IEEE 802.11a 两 个 规范 的 工作 频段 不 一 样 ， 相 互 不 兼容 ， 致 使 一 些 原 
先 购买 IEEE 802.11b 规 范 的 无 线 网 络 设备 在 新 的 802.11a 网 络 中 不 能 
用 ,于 是 推出 一 个 兼容 两 个 规范 的 新 规范 就 成 了 事实 之 需 ， 那 就 是 
2003 年 6 月 IEEE 正 式 推 出 IEEE 802.11g 规 范 。 


IEEE 802.11g 规 范 的 主要 特性 如 下 : 
(1) 工作 频段 


IEEE 802.11g 规 范 与 IEEE 802.11b 规 范 一 样 工作 在 免费 的 2.4GHz 频 
段 (与 IEEE 802.11b 兼 容 ， 但 不 与 IEEE 802.11a 兼 容 ) ， 室 内 有 效 传输 
距离 38m， 室 外 有 效 传输 距离 140m 。 


(2) 传输 速率 


IEEE 802.11g 规 范 具有 与 IEEE 802.11a 规 范 一 样 的 传输 速率 
(54Mbps) ， 总 带宽 为 20MHz， 如 果 需 要 的 话 ， 传 输 速 率 可 降 为 


48Mbps、36Mbps、24Mbps、18Mbps、12Mbps、9Mbps 或 者 6Mbps 。 


IEEE 802.11g 规 范 共 划分 了 13 个 信道 ， 如 表 6-10 所 示 ， 每 个 信道 所 
履 盖 的 频率 范围 如 图 6-62 所 示 ， 不 同 的 只 是 IEEE 802.11g 规 范 中 12、13 
号 这 两 个 信道 是 可 用 的 。 在 这 13 个 信和 道中， 真正 完全 不 重 仅 的 信道 最 
多 也 只 有 3 个 ， 有 五 种 组 合 ， 那 就 是 : 1、6 和 11 (或 13) 号 信道 ，2、 
和 12 号 信道 ，3、8 和 13 号 信道 ，4 和 9 号 信道 ， 以 及 5 和 10 号 信道 ， 每 个 
区 域 WLAN 网 络 只 能 选择 其 中 一 组 ， 美 国 是 推荐 使 用 1、6 和 11 这 组 信 
道 ， 但 世界 上 大 多 数 国家 还 推荐 使 用 、5、9、13 这 组 信道 ， 这 样 就 可 
以 在 同一 个 区 域 WLAN 网 络 中 部 署 4 台 AP 了 “。 为 保证 这 部 分 区 域 所 使 
用 的 信号 信道 不 能 互相 覆盖 ， 各 AP 要 使 用 不 同 的 信道 ， 最 好 选择 完全 
不 重 又 的 一 组 信道 。 
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(4) 调制 方法 
IEEE 802.11g 规 范 同时 采用 了 IEEE 802.11a 中 的 OFDM 与 IEEE 
802.11b 中 的 DSSS、CCK 等 多 种 调制 技术 。 


(5) 主要 安全 技术 


在 安全 性 方面 ，IEEE 802.11g 规 范 全 面 文 持 IEEE 802.11i 标 准 中 的 
WPA、WPA2、EAP (Extensible Authentication， 可 扩展 身份 认证 ) 
AES(Advanced Encryption Standard， 高 级 加 密 标 准 ) 加 密 ， 以 及 用 于 访 
问 控制 的 IEEE 802.1x 标 准 。 


说 明 ”在 以 上 这 三 个 主要 无 线 局 域 网 接 入 规范 之 外 ， 我 们 还 可 见 
到 诸如 IEEE 802.11b+、IEEE 802.11a+ 和 IEEE 802.11g+ 这 三 个 所 谓 对 应 
规范 的 增强 版 ， 它 们 的 传输 速度 也 相应 增强 ， 达 到 原 有 规范 的 2 倍 ， 分 
别 为 22Mbps、108Mbps 和 108Mbps。 但 这 三 个 所 谓 的 增强 版 规范 并 非 
正式 的 规范 ， 而 是 一 些 无 线 网 络 设备 开发 商 目 己 制定 的 企业 规范 ， 它 
们 的 兼容 性 较 差 ， 通 党 只 能 与 本 企业 某 些 无 线 网 络 设备 相 兼 容 。 


6.14.4 IEEE 802.11n 规 范 主要 特性 


IEEE 802.11n， 是 2009 年 9 月 正式 发 布 的 IEEE 新 的 802.11 规 范 ， 也 
是 目前 最 主要 应 用 的 WLAN 接 入 规范 。 其 主要 特性 如 下 : 


(1) 工作 频段 


IEEE 802.11n 规 范 可 工作 在 2.4GHz 和 5GHz 两 个 频段 ， 所 以 它 可 以 
全 面向 下 兼容 以 前 发 布 的 IEEE 802.11b/a/g 这 三 个 规范 以 。 


(2) 传输 速率 


IEEE 802.1ln 规 范 在 标准 带宽 (20MHz) 单 倍 MIMO 上 支持 的 速率 
有 7.2Mbps、14.4Mbps、21.7Mbps、28.9Mbps、43.3Mbps、 
57.8Mbps、65Mbps、72.2Mbps， 使 用 标准 带宽 和 4 倍 MIMO 时 ， 最 高 
速率 为 300Mbps; 在 2 倍 带 宽 (40MHz) 和 4 倍 MIMO 时 ， 最 高 速率 可 


达 600Mbps， 是 最 近 的 IEEE 802.11g 的 10 倍 多 。 


IEEE 802.11n 规 范 总 共 可 以 有 15 个 不 相互 重 又 的 信道 ， 其 中 在 
2.4GHz 频 段 中 有 3 个 不 相互 重 到 的 信道 ， 在 SGHz 频 段 中 有 12 个 不 相互 
重 谷 的 信道 。 男 外 ， 通 过 将 两 个 相 邻 的 20MHz 带 宽 捆 绑 在 一 起 组 成 一 


个 40MHz 通 信 带 宽 ， 在 实际 工作 时 可 以 作为 两 个 20MHz 的 带宽 使 用 

(一 个 为 主 带 宽 ， 一 个 为 次 带宽 ， 收 发 数据 时 既 能 以 40MHz 的 带 视 工 
作 ， 也 能 以 单个 20MHz 带 宽 工 作 ) ， 这 样 可 将 速率 提高 一 倍 。 同 时 ， 

对 于 IEEE 802.11a/b/g， 为 了 防止 相 邻 信道 干扰 ，20MHz 带 虹 的 信道 在 
其 两 侧 预 留 了 一 小 部 分 的 带宽 边界 。 而 通过 频带 绑 定 技术 ， 这 些 预 留 
的 市 宽 也 可 以 用 来 通信 ， 从 而 进一步 提高 吞吐 量 。 


(4) 调制 方法 


IEEE 802.11n 规 范 采 用 了 IEEE 802.11g 规 范 中 相同 的 OFDM 调 制 技 
术 ， 只 是 选择 的 正 交 载波 数 更 多 。OFDM 可 将 信道 分 成 许多 进行 窗 带 
调制 信道 和 传输 正 交 子 信道 ， 并 使 每 个 子 信道 上 的 信和 号 带宽 小 于 信道 
的 相关 带宽 ， 用 以 减少 各 个 载波 之 间 的 相互 干扰 ， 同 时 提高 频谱 的 利 
用 率 。MIMO (Multiple-Input and Multiple-Output， 多 进 多 出 ) 与 


OFDM 技 术 的 结合 ， 就 产生 了 MIMO OFDM 技 术 ， 它 通过 在 OFDM 传 
输 系统 中 采用 阵列 天 线 实现 空间 分 集 ， 提 高 信号 质量 ， 并 增加 多 径 的 
容 限 ， 使 无 线 网 络 的 有 效 传输 速率 有 质 的 提升 。 


(5) 主要 安全 技术 


IEEE 802.11n 规 范 与 IEEE 802.11g 规 范 所 使 用 的 主要 安全 技术 类 
似 ， 主 要 都 是 IEEE 802.11i 所 引入 的 WPA、WPA2 和 AES 加 密 ， 以 及 
IEEE 802.1x 访 问 控制 技术 。 


6.14.5 ”两 个 未 正式 发 布 的 新 规范 简介 


在 IEEE WLAN 接 入 规范 中 ， 目 前 还 有 两 个 靳 的 规范 正在 研发 ， 并 
旦 按 计划 都 即将 发 布 ， 那 就 是 前 面 提 到 的 IEEE 802.11ac 和 IEEE 
802.11ad。 因 为 最 终 的 规范 特性 未 正式 发 布 ， 所 以 在 此 也 仅 作 简单 的 
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在 我 们 还 没有 全 面 应 用 IEEE 802.11n 规 范 的 时 候 ， 新 一 轮 的 无 线 
提速 攻势 又 迎面 扑 来 ， 那 融 是 即将 发 布 的 IEEE 802.11ac 和 IEEE 
802.11ad 规 范 。 与 IEEE 802.11n 规 范 不 同 的 是 ， 这 两 个 新 规范 不 再 在 个 
留 在 百 兆 级 别 ， 而 是 要 将 整个 WLAN 也 提高 到 了 千 兆 领域 ， 也 将 会 
容 目 前 发 布 的 全 系列 IEEE 802.11 规 范 。 


IEEE 802.11ac 规 范 的 核心 技术 主要 基于 IEEE 802.11a， 继 续 工作 
在 5.0GHz 频 段 上 以 保证 向 下 兼容 性 ， 但 由 于 数据 传输 通道 的 大 大 扩 
充 ，IEEE 802.11ac 规 范 的 入 门 级 速度 天 可 以 达到 433Mb/s， 高 端 设备 
会 达到 3.2Gb/s， 使 VWLAN 真 正 进 入 千 兆 时 代 。 


IEEE 802.11ac 规 范 继续 用 IEEE 802.11n 规 范 的 MIMO 技 术 ， 但 进行 
了 增强 。IEEE 802.11n 规 范 的 数据 传输 通道 宽度 为 20/40MHz， 最 大 能 
x 


前 
提供 600Mb/s 下 载 速 度 ， 而 80MHz 信 道 宽度 的 IEEE 802.11ac， 在 3x3 


MIMO 模 式 下 就 能 提供 1.3Gb/s 的 下 载 速度 ， 如 果 信 道 守 上 度 为 160MHLz， 


该 速度 则 是 高 达 2.6Gb/s。 


虽然 在 2008 年 制定 此 规范 时 IEEE 工 作 组 就 将 目标 定位 在 2012 年 ， 
但 由 于 IEEE 802.11 系 列 规范 一 同 都 症 先 有 鸡 后 有 和 蛋 ， 产 品 比 规范 早出 
的 特点 ， 所 以 目前 我 们 实际 上 已 经 看 到 了 主流 网 络 设备 厂商 的 实验 性 
IEEE 802.11ac 产 品 。 如 全 球 领 乞 的 心 斤 广 商 Broadcom 正 式 公 布 了 IEEE 
802.11ac 心 片 ， 随 后 包括 华硕 、 贝 尔 金 、D-Link、 华 为 、 联 想 等 一 系 
列 网 络 广 商都 相继 声称 将 很 快 提 供 基于 这 一 规范 的 WLAN 产 品 。 


如 果 前 一 个 IEEE 802.11ac 主 要 是 用 来 接替 IEEE 802.11a/g 规 范 主 要 
应 用 于 企业 WLAN 中 的 话 ， 那 同时 研发 的 千 兆 级 IEEE 802.11ad 规 范 则 
主要 面向 家 庭 娱 乐 视频 、 音 频 设 备 ， 且 工作 在 与 前 面 所 有 IEEE 802.11 
接 入 规范 工作 频段 不 同 的 60GHz 频 段 上 。IEEE 802.11ad 规 范 的 主要 目 
标 能 够 使 得 高 清 视 频 和 无 损 音 频 成 为 可 能 ， 为 家 庭 多 媒体 应 用 带 来 更 
完备 的 高 清 视 频 解决 方案 。 


在 技术 上 ，IEEE 802.11ad 规 范 仍然 使 用 目 IEEE 802.11n 规 范 所 引 
入 的 MIMO 技 术 来 实现 多 路 传输 ， 将 使 单一 信道 传输 速率 过 1Gbps， 最 
高 传输 速率 可 以 达到 7.2Gbps。IEEE 802.11n 最 多 能 支持 4x4 MIMO， 
而 IEEE 802.11ac 则 是 支持 8x8 MIMO， 而 802.11ad 更 是 可 以 支持 10x10 
MIMO 以 上 。 


6.14.6 ”其 他 主要 WLAN 规 范 


除了 以 上 介绍 的 几 个 当前 主要 的 WLAN 接 入 规范 外 ， 还 有 一 些 其 
他 无 线 局 域 网 规范 。 


1.IEEE 802.11e 
IEEE 802 工 作 组 于 2005 年 年 底 正 式 推 出 了 IEEE 802.11e 规 范 。 该 规 
范增 强 了 原 有 的 IEEE 802.11MAC 信 道 接 入 方式 ， 在 原来 的 DCF (分 布 


式 信 道 功能 ， 和 PCF 《点 信道 功能 ) 基础 上 引入 了 一 种 新 的 接 入 机 制 


HCF (Hybrid Channel Funcation， 混 合 信道 功能 ) 。 


HFC 定 义 了 两 种 服务 质量 提供 机 制 : 竞争 性 信道 接 入 机 制 EDCA 
(Enhanced Distributed Channel Access， 增 强 型 分 布 式 信道 访问 ) 与 非 


竞争 (中心 控制 ) 接 入 机 制 HCCA (HCF，Controlled Channel 
Access， 混 合 协调 功能 控制 信道 访问 )。 简 地 说 ，EDCA 和 HCCA 分 别 
就 是 DCF 和 PCF 的 增强 版 ，EDCA 只 能 在 竞争 期 内 使 用 ， 提 供 了 不 同 优 
先 级 的 QoS，HCCA 扩 展 了 PCF， 在 竞争 期 和 非 竞 争 期 内 均 可 使 用 ， 提 
供 了 参数 化 的 QoS。 


EDCA 指 定 了 四 种 访问 类 型 ， 每 一 种 类 型 对 应 一 类 数据 。 每 一 个 
访问 类 别 配置 了 四 个 参数 ， 它 们 分 别 是 :最 小 竞争 窗口 (Minimum 


Contention Window，CWmin) ， 最 大 竞争 窗口 (Maximum Contention 
Window，CWmax) ， 传 送 机 会 (Transmission Opportunity， 

TXOP) ， 仲 裁 帧 间 间 隔 (Arbitration Inter Frame Space，AIFS) 。 为 

每 一 类 数据 设置 这 些 参数 能 够 让 网 络 管理 员 根 据 应 用 程序 组 合 和 通信 
量 调整 网 络 。 


ECDA 是 对 原 有 的 DCF 机 制 中 的 CSMA/CA (Carrier Sense Multiple 
Access/Collision Avoidance， 载 波 侦 听 多 路 访问 /冲突 避免 的 扩展 ， 
用 来 保证 对 不 同 的 数据 流 提供 不 同 的 QoS。 与 DCF 相 比 ，ECDA 机 制 从 
两 全 方面 进行 服务 质量 的 区 分 : 一 是 基于 退 避 机 制 ， 为 具有 不 同 服务 
质量 要 求 的 数据 流 分 配 不 同 的 CWmin 和 CWmax， 而 DCF 中 对 所 有 数据 
流 的 这 两 个 参数 是 一 样 的 ， 二 是 基于 仲裁 帧 间 间 隔 AIFS， 也 就 是 在 接 
入 信道 前 站 点 必须 等 待 的 信道 空闲 时 间 ， 在 DCF 中 ， 每 个 站 点 必须 等 
待 的 信道 空 闪 时 间 均 为 DIFS (DCF 帧 间 间 隔 ) ， 而 在 EDCA 中 ， 每 个 
站 点 等 待 的 时 间 是 不 同 的 ， 由 公式 AIFS=SIFS (最 短 帧 间 间 隔 ) 
+AIFSN*Q 来 计算 。 通 过 分 配 不 同 的 AIFSN 值 ， 就 可 以 获得 不 同 的 服 


务 


质量 。 
2.IEEE 802.11i 


这 是 IEEE 提 出 的 新 一 代 WLAN 安 全 规范 ， 实 际 上 是 把 1999 年 制定 
的 原 用 于 有 线 以 太 网 的 IEEE 802.1x 安 全 规范 引入 了 WLAN， 用 于 取代 
以 前 的 WEP 加 密 规 范 。 它 在 加 密 处 理 中 引入 了 TKIP (Temporal Key 


Integrity Protocol， 临 时 密 钥 完整 性 协议 ) ， 使 得 用 于 链 路 加 密 的 密 钥 
从 静态 转变 为 动态 。 虽 然 还 是 基于 RC4 算 法 ， 但 比 采用 静态 密 钥 的 
WEP 先 进 。 除 了 密 钥 管理 以 外 ， 它 还 具有 以 EAP (Extensible 
Authentication Protocol， 可 扩展 认证 协议 ) 为 核心 的 用 户 审 核 机 制 ， 
可 以 通过 服务 器 审核 接 入 用 户 的 ID， 在 一 定 程 度 上 可 避免 了 黑客 非法 
接 入 。 


IEEE 802.11i 拥 有 如 下 的 关键 安全 技术 : 


(1) 暂时 密 钥 完整 性 协议 (TKIP) 


TKIP 负 责 处 理 无 线 安全 问题 的 数据 加 密 部 分 。TKIP 是 包 囊 在 已 有 
WEP 密 码 外 围 的 一 层 “ 外 壳 ”， 由 WEP 使 用 的 同样 的 加 密 引 警 和 RC4 算 
法 组 成 。 不 过 ，TKIP 中 密码 使 用 的 密 钥 长 度 为 128 位 ， 且 它 为 每 个 数 
据 所 使 用 的 密 钥 是 动态 变化 的 ， 安 全 性 更 高 。 


(2) CBC-MAC 计 数 模式 协议 (CCMP) 


CCMP (Counter mode with CBC-MAC Protocol， 支 持 CBC-MAC 
协议 的 计数 器 模式 ) 是 IEEE802.11i 中 要 求 强 制 实 现 的 新 加 密 算法 。 
CCMP 在 计数 模式 下 采用 了 AES 的 算法 ， 使 用 了 CBC-MAC (Cipher 
Block Chaining Message Authentication Code， 密 码 块 链 消 息 验 证 码 ) 
模式 ， 以 请 妃 块 作为 运算 基础 ， 最 后 产生 消 息 块 认证 码 。 在 IEEE 


802.11i 规 范 中 ，CCMP 使 用 了 128 位 的 密 钥 ， 可 以 对 数据 进行 更 加 有 效 
的 加 密 保护 。 


(3) IEEE802.1x 


IEEE 802.1x 问 受 保护 的 网 络 提供 了 一 个 有 效 的 号 份 验 证 和 用 户 通 
信 管 理 的 框架 ， 


同时 还 能 动态 地 改变 密 钥 。IEEE 802.1x 在 有 线 和 无 线 
局 域 网 媒介 中 都 捆绑 了 可 扩展 身份 验证 协议 (EAP) ， 并 支持 多 重 身 


份 验证 。 


(4) EAPOL 


EAPOL (Extensible Authentication Protocol Over LAN， 基 于 局 域 
网 的 扩展 身份 验证 协议 ) 是 802.1x 协 议定 义 的 一 种 报 文 封装 格式 ， 主 


要 用 于 在 客户 端 和 设备 端 之 间 传 送 EAP 协 议 报 文 ， 以 允许 EAP 协 议 报 
文 在 局 域 网 中 传送 。 


3.IEEE 802.11f 


IEEE 802.11{ 规 范 解决 了 不 同 规范 访问 点 (AP) 之 间 的 漫游 通信 


问题 ， 所 用 的 主要 协议 是 IAPP (Inter-Access Point Protocol， 接 入 点 间 
协议 ) 。 它 主要 解决 IEEE 802.11 系 列 各 接 入 规范 在 网 间 互 连 方面 存在 
的 不 足 。 用 户 在 两 个 不 同 的 交换 网 段 (无 线 信道 ) 或 两 种 不 同类 型 无 


线 网 的 接 入 点 间 进 行 漫游 时 ， 通 过 该 协议 可 更 好 地 维护 网 络 连接 ， 此 
时 无 线 LAN 具 备 蜂 氏 电 话 那 样 的 灵活 性 显得 至 天 重要 。 


4.IEEE 802.11h 


IEEE 802.11h 用 于 802.11a 的 频谱 管理 技术 ， 增 加 了 传输 功率 控制 
和 动态 频率 选择 。 它 力图 在 传输 功率 和 无 线 信 道 选 择 上 比 IEEE 
802.11a 更 胜 一 筹 ， 主 要 在 欧洲 使 用 。 


6.14.7 WLAN MAC 幅 格式 


在 WLAN 体 系 结构 中 ，MAC 子 层 有 两 种 工作 方式 :分布 式 协调 功 
能 (DCF) 和 点 协调 功能 (PCF) ， 但 MAC 子 层 帧 结构 均 如 图 6-63 所 
a 
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图 。6-63 ”WLAN/RM 中 的 MAC 帧 结构 
下 面 对 各 图 6-63 所 示 字 段 进行 具体 介绍 。 


1) Frame Control (FC， 帧 控制 ) 字段 


FC 字段 占 2 个 字 节 ， 用 于 控制 MAC 子 层 帧 信息 和 行为 。 在 这 个 字 
段 的 2 个 字 节 中 文 包括 如 网 6-64 所 示 的 结构 。 


2 4 1 1 1 1 1 1 1 1 位 
ca fore T More 
brotoe ol Type Subtype To DS From DS Retry ee WEP | Order 
Version - Flag 2 Megt Data 


图 6-64 FC 字段 结构 


口 Protocol Version: 协议 版 式 本 字段 ， 占 2 位 。 表 示 IEEE 802.11 规 
范 版 本 。 


DType: 帧 类 型 字段 ， 占 2 位 。 巾 类 型 包括 管理 、 控 制 和 数据 三 种 


口 Subtype: 帧 子 类 型 字段 ， 占 4 位 。 帧 子 类 型 包括 认证 帧 
(Authentication Frame) 、 解 除 认 证 帧 (Deauthentication Frame) 、 连 
接 请 求 帧 (Association Request Frame) ， 连 接 响 应 帧 (Association 
Response Frame) 、 重 新 连接 请 求 帧 (Reassociation Request Frame) 、 
重新 连接 响应 帧 (Reassociation Response Frame) 解除 连接 帧 


(Disassociation Frame) 、 信 标 由 (Beacon Frame) 、Probe 幅 (Probe 
Frame) 、Probe 请 求 帧 (Probe Request Frame) 或 Probe 响 应 帧 (Probe 


Response Frame) 。 


DTo DS: 到 分 布 式 系统 的 帧 字段 ， 占 1 位 。 当 帧 是 发 送 给 
Distribution System (DS) 时 ， 该 值 设置 为 1。 


口 From DS: 来 目 分 布 式 系 统 的 帧 字段 。 当 帧 是 从 DS 处 接收 到 时 ， 
该 值 设置 为 1。 


口 More Fragment: 更 多 分 片 字段 ， 占 1 位 。 表 示 当 前 帧 后 面 还 有 更 
多 分 段 属 于 相同 帧 时 ， 该 值 设 置 为 1， 否 则 设 为 0。 


口 Retry: 重 传 字段 ， 占 1 位 。 如 是 重 传 帧 则 用 1 表示 ， 和 否则 用 0 表 


修 ° 


口 Pwr Mgt: Power Management， 电 源 管 理 字 段 ， 占 1 位 。 表 示 在 
帧 传输 后 ， 站 点 所 采用 的 电 庆 管理 模式 。1 表 示 采 用 区 能 模式 ，0 表 示 
活动 模式 。 


口 More Data: 更 多 数据 字段 ， 占 1 位 。1 表 示 在 AP 缓存 中 还 有 从 分 
布 式 系统 到 节能 模式 站 点 的 帧 ，0 表 示 没 有 。 


口 WEP: 加 密 字 段 ， 占 1 位 。1 表 示 采 用 WEP (Wired Equivalent 
Privacy) 算法 对 帧 数据 进行 加 密 ，0 表 示 不 加 密 。 


口 Order: 顺序 字段 ， 占 1 位 。1 表 示 按 顺序 发 送 帧 或 者 分 段 ，0 表 示 
不 按 顺 序 发 送 。 


2) Duration/ID 


Duration/ID 为 持续 时 间 字 段 ， 占 2 字 节 。 当 第 15 位 为 0 时 ， 用 于 议 
置 NAV (网 络 分 配 向 量 ) ，NAV 等 于 在 当前 传输 中 介质 忙 的 时 间 (以 
毫秒 计 ) 长 。 这 样 所 有 站 点 就 会 监控 接收 到 的 帧 送 ， 并 更 新 NAV 。 


在 IEEE 802.11 WLAN 网 络 内 ， 所 有 接收 到 RTS (Request to Send， 
请 求 发 送 ) 与 CTS (Clear to Send， 清 理 后 发 送 ) 信号 的 无 线 设 备 ， 都 
将 采用 虚拟 介质 检测 (Virtual Carrier Sense，VCS) 机 制 ， 设 置 NAV 


(Network Allocation Vector， 网 络 分 配 矢 量 ) ， 并 使 用 在 RTS 和 CTS 中 

包含 的 Duration/ID 字 段 信 息 来 设置 MAC 参 数 NAV，Duration/ID 字 上 段 指 
明了 源 和 目的 主机 为 传输 数据 将 要 占用 信道 的 时 间 长 度 。 当 物理 层 内 
的 NAV 指 针 打 开 时 ， 设 备 将 认为 此 时 的 物理 介质 正 被 其 他 设备 所 占用 
而 停止 发 送 与 接收 数据 。NAV 的 值 随 着 时 间 推 移 不 断 减 小 ， 在 NAV 值 
减 到 零 之 前 ， 主 机 不 会 发 起 传输 党 试 。 


VCS 机 制 设置 使 其 他 主机 预先 知道 信道 中 正在 进行 的 传输 情况 ， 
从 而 有 效 提高 了 数据 帧 成 功 传输 的 概率 。 但 是 VCS 机 制 增加 了 RTS 和 
CTS 的 开销 ， 降 低 了 有 效 数 据 传输 速率 。NAV 的 设计 有 助 于 解决 无 线 局 
域 网 内 隐藏 节点 的 问题 。 


在 没有 冲突 发 生 时 ， 第 14 位 为 0， 第 15 位 为 1， 所 有 其 他 位 为 0° 这 
样 得 出 的 NAV 值 为 32768。 所 有 站 点 会 在 无 冲突 期 间 更 新 NAV 值 ， 以 免 
发 生 冲 突 。 


3) Address 


Address 为 地 址 列表 字段 ， 包 括 图 6-63 中 的 4 个 地 址 (Address 1、 
Address 2、Address 3、Address 4， 这 里 当然 是 MAC 地 址 了 ) 字段 ， 它 
们 依次 对 应 : 接收 者 地 址 、 发 送 者 地 址 、 源 地 址 和 目标 地 址 。 每 个 地 
址 字段 占 6 字 节 〈48 位 ) 。 这 4 个 字段 对 于 所 有 MAC 帧 来 说 并 不 是 都 需 
要 的 ， 是 否 需 要 取决 于 帧 类 型 。 


当 第 1 位 为 0 时 ， 表 示 该 地 址 为 单一 站 点 所 用 的 单 播 地 址 ， 当 第 1 位 
为 1 时 ， 表 示 该 地 址 对 应 一 组 站 点 的 组 播 地 址 ;如 条 所 有 位 均 为 1， 则 
表示 该 帆 为 广播 帆 。 


4) Sequence Control 


Sequence Control 为 序列 控制 字段 ， 占 2 字 节 。 它 是 由 分 段 二 和 序列 
号 组 成 ， 用 于 表示 同一 帧 中 不 同 分 段 的 顺序 ， 并 用 于 识别 数据 包 副 
本 。 其 中 高 4 位 表示 分 段 号 ， 从 0 开始 计数 ， 步 长 为 1。 后 12 位 是 序列 号 
(也 就 是 优先 级 号 ) ， 用 于 决定 以 模 为 4096 的 传输 帧 计数 器 ， 也 是 从 0 
开始 的 ， 步 长 为 1°。 同一 帧 的 分 段 ， 序 列 号 是 一 样 的 。 


5) Data 


Data 为 数据 字段 。 发 送 或 接收 的 信息 。 最 大 的 帧 为 2312 字 节 ， 其 
中 包括 8 字 节 的 802.11 LLC 头 ， 加 上 2296 字 节 的 净 负 信和 和 WEP 开销 。 如 
果 此 字段 为 空 ， 则 表示 该 帧 为 控制 和 管理 帧 。 


6) Frame Check Sum 


Frame Check Sum 为 帧 校 验 序列 ， 即 CRC (Cydlic Redundancy 
Check， 循 环 元 余 校 验 ) ， 占 4 字 节 。 用 于 校 验 帧 的 完整 性 ， 校 验 时 必 
须 对 除 FCS 字 段 外 的 其 他 字段 一 起 进行 计算 。 


第 7 章 网络 层 


如 有 果 我 们 把 物理 层 和 数据 链 路 层 比 作 市 内 交通 ， 那 么 本 章 所 要 介 
绍 的 网 络 层 残 可 以 比 作 连 接 不 同城 市 交通 的 中 转 芋 站、 机 场 或 码头 。 
残 像 中 转车 站 、 机 场 或 码头 可 以 把 来 目 其 他 城市 的 旅客 送 到 下 一 站 或 
本 市 目的 地 一 样 ， 网 络 层 可 以 把 来 日 其 他 网 络 中 的 数据 传送 到 下 一 个 
途经 的 网 络 或 本 网 络 中 的 目的 太 感 。 当 源 端 和 目的 端 位 于 不 同 网 络 的 
时 候 ， 直 接 通信 是 不 可 行 的 ， 此 时 就 需要 由 网 络 层 解决 。 


网 络 层 (在 TCP/IP 体 系 结构 中 称 为 网 际 互 连 层 ) 是 网 络 体系 结构 
中 非常 重要 的 一 层 ， 在 技术 上 又 是 非 第 复杂 的 一 层 ， 因 为 它 既 要 解决 
不 同 网 络 的 节点 间 通 信 的 路 由 和 协议 识别 问题 ， 又 要 通过 路 由 选择 沉 
格 解 决 网 络 拥塞 问题 ， 尽 可 能 提高 网 络 通信 的 可 靠 性 。 网 络 层 关注 的 
征 如 何 将 分 组 从 源 病 沿 厦 网 络 路 径 传送 到 目的 咒 。 为 了 实现 这 个 目 
标 ， 网 络 层 必 须知 道 通信 子 网 的 拓扑 结构 ， 并 且 在 拓扑 结构 中 选择 适 
当 的 路 径 。 同 时 网 络 层 还 必须 齐 愤 地 选择 路 由 路 径 ， 以 避免 发 生 某 些 
通信 线路 和 路 由 右 人 负载 过 重 ， 而 其 他 线路 和 路 由 右 空 内 的 情形 。 


本 章 主 要 讨论 网 络 层 的 主要 功能 、 主 要 服务 类 型 、 主 要 路 由 算 
法 、 拥 塞 控制 方法 及 原理 、 主 要 网 络 层 通 信 协 议 报 文 格式 和 工作 原 
理 ， 以 及 三 层 交换 原理 。 关 于 IP 地 址 及 子 网 划分 将 在 第 8 章 介 绍 ， 关 于 
主要 的 动态 路 由 协议 及 工作 原理 将 在 本 书 第 9 章 介 绍 。 


7.1 网络 层 概述 


本 书 前 面 介绍 的 物理 层 和 数据 链 路 层 构建 了 局 域 网 内 部 的 通信 线 
路 ， 相 当 于 一 个 城市 内 部 的 交通 路 线 。 本 章 要 介绍 的 网 络 层 就 是 用 来 
连接 不 同 局 域 网 线路 的 结 点 ， 位 于 不 同 网 络 的 边 绿 ， 残 相当 于 各 城市 
边缘 ， 用 于 连接 不 同城 市 交通 线路 的 中 转 站 点 一 样 。 


7.1.1 划分 网 络 层 的 必要 性 


网 络 层 是 从 功能 上 定义 的 一 个 逻辑 层次 ， 与 物理 层 和 数据 链 路 层 
有 具体 的 设备 文 持 一 样 ， 网 络 层 也 有 具体 的 设备 来 完成 其 相关 任务 ， 
最 典型 的 就 是 我 们 常用 的 路 由 器 (Router) 。 路 由 器 就 相当 于 连接 不 同 
城市 公路 的 中 转车 站 ， 起 数据 中 转 作 用 ， 如 图 7-1 所 示 。 每 个 路 由 紫 至 
少 可 连 毛 两 个 网 络 ， 束 像 一 个 城市 的 中 转车 站 可 以 连接 多 个 城市 内 的 
交通 一 样 。 


N| 


主机 1 主机 2 


应 用 层 应 用 层 


表示 层 表示 层 

会 话 层 路 由 器 1 路 由 器 2 会 话 层 

传输 层 Ee -~ 传输 层 

网 络 层 网 络 层 网 络 层 网 络 层 
数据 链 路 层 数据 链 路 层 数据 链 路 层 数据 链 路 层 
物理 层 物理 层 物理 层 物理 层 


图 7-1 不 同 网 络 的 连接 示例 


网 络 层 是 OSI 参考 模型 中 的 第 三 层 (对 应 TCP/IP 协 议 体系 结构 中 的 
第 二 层 一 一 网 际 互 连 层 ) ， 介 于 传输 层 和 数据 链 路 层 之 间 。 总 的 来 
说 ， 网 络 层 的 主要 作用 是 实现 两 个 网 络 系统 之 间 的 数据 透明 传送 ， 有 具 
体 包括 路 由 选择 、 拥 塞 控 制 和 网 际 互 连 等 。 网 络 层 是 端 到 端 (也 就 是 
网 络 与 网 络 之 间 ) 网 络 通信 的 最 低层 ， 在 数据 从 数据 链 路 层 向 传输 层 
进行 数据 传输 的 通信 中 ， 起 到 构建 一 个 中 间 通 信子 网 的 作用 。 它 负责 
与 它 上 面 的 资源 子 网 (OSIRM 参 考 模型 传输 层 及 以 上 的 四 层 ) 联系 ， 
是 OSVRM 七 层 参考 模型 中 面向 网 络 通 信 的 低 三 层 (也 即 “ 通 信子 网 ”) 
中 最 为 复杂 、 关 键 的 一 层 。 


网 络 层 是 计算 机 网 络 发 展 的 产物 ， 但 并 不 是 有 了 计算 机 网 络 束 有 
了 它 。 在 早期 的 计算 机 网 络 中 ， 基 本 上 有 是 以 独立 的 局 域 网 形式 存在 ， 


而 我 们 知道 ， 在 局 域 网 内 部 完全 可 以 通过 由 物理 层 和 数据 链 路 层 共同 
构建 的 通信 和 链 路 来 实现 各 计算 机 用 户 之 间 的 通信 访问 ， 所 以 也 就 无 需 
其 他 层次 ， 包 括 网 络 层 。 况 且 当 时 计算 机 网 络 的 应 用 比较 有 限 ， 各 局 
域 网 之 间 也 不 存在 相互 通信 的 必要 性 ， 所 以 这 些 局 域 网 也 束 无 须 相 互 
连接 。 但 随 着 计算 机 网 络 的 普及 和 发 展 ， 人 们 越 来 越发 现 ， 非 常 有 必 
要 把 这 些 一 个 个 孤立 的 局 域 网 连接 起 来 ， 组 成 一 个 更 大 的 计算 机 网 
络 ， 这 样 计 算 机 网 络 的 作用 更 能 显现 ， 可 使 更 多 人 共享 服务 右 和 硬件 
换 源 。 这 吏 涉 及 计算 机 网 络 间 的 互 连 问 题 了 。 


那 为 什么 要 这 样 一 个 网 络 层 呢 ? 其 实 道理 很 简单 ， 就 是 因为 不 同 
网 络 有 不 同 的 网 络 放 协议 和 地 址 规范 ， 一 个 网 络 中 的 用 户 知 不 能 识别 
其 他 网 络 的 通信 协议 和 地 址 规范 ， 束 不 能 把 数据 从 一 个 网 络 传送 到 田 
一 个 网 络 中 。 束 像 不 同城 市 有 不 同 的 交通 法 规 ， 属 于 不 同 的 交警 系统 
管理 ， 不 允许 外 地 车 辆 随便 出 入 一 样 ， 不 同 网 络 也 有 不 同 的 设计 规 
范 ， 属 于 不 同 的 组 织 来 管理 ， 必 须 通过 授权 ， 并 由 专门 的 协议 来 负责 
网 络 间 的 通信 。 


通常 一 个 计算 机 网 络 就 是 一 个 管理 边界 ， 一 般 是 属于 一 个 特定 的 
公司 ， 由 一 个 特定 的 管理 者 人 负责。 所 以 在 进行 计算 机 网 络 互 连 时 ， 要 
同时 考虑 两 方面 的 问题 : 一 是 授权 用 户 可 以 在 不 同 网 络 间 互 访 ， 共 享 
双方 的 资源 ; 另 一 方面 又 要 保持 各 计算 机 网 络 管理 原来 的 独立 性 ， 所 
以 不 能 简单 地 通过 拉 一 条 网 线 就 把 问题 解决 了 这样 无 法 解决 管理 独 


立 性 问题 ) 。 事 实 上 ， 在 许多 环境 中 ， 一 般 企 业 是 不 可 能 把 两 个 位 于 
不 同城 市 甚至 不 同 国家 的 计算 机 网 络 通过 拉线 的 方式 互 连 起 来 的 。 


在 第 6 章 中 讲 到 ， 局 域 网 内 部 的 用 户 访问 也 是 需要 寻 址 的 ， 即 通过 
MAC 地 址 (又 称 硬件 地 址 ) 进行 。 但 MAC 地 址 属于 数据 链 路 层 地 址 ， 
不 能 跨 网 进行 寻 址 ， 那 么 在 不 同 网 络 间 进 行 访问 时 又 是 通过 什么 地 址 
来 进行 寻 址 呢 ? 那 就 是 网 络 层 的 功能 了 “。 在 网 络 层 也 有 一 种 对 应 的 地 
址 ， 即 网 络 地 址 ， 每 个 网 络 都 通过 其 网 络 地 址 ， 即 NSAP (网 络 服务 访 
问 点 ) 来 标识 ， 网 络 中 的 每 个 节点 都 有 一 个 NSAP。 这 个 NSAP 就 是 由 
对 应 网 络 所 运行 的 网 络 层 通 信 协 议 来 定义 的 。 在 目前 最 常见 的 TCP/IP 
协议 网 络 中 ， 这 个 协议 就 是 IP 协 议 ， 对 应 的 NSAP 就 是 IP 地 址 。 本 书 仅 
以 TCP/IP 网 络 (其 实 也 就 是 TCP/IP 协 议 体 系 结构 中 的 网 络 互 连 层 ) 为 
例 进 行 介绍 。 有 关 IP 协 议和 JIP 地 址 方面 的 内 容 将 在 第 8 章 介 绍 。 


在 前 面 已 说 到 ， 在 物理 层 传输 的 是 一 个 个 比特 位 (bit) ， 在 数据 
链 路 层 中 传输 的 是 一 个 个 以 许多 字 节 为 单位 的 帧 (Frame) ， 在 每 个 帧 
的 帧 头 都 有 源 节 点 的 MAC 地 址 和 目的 节点 的 MAC 地 址 ， 局 域 网 内 部 的 
寻 址 就 是 通过 MAC 地 址 进行 的 ， 而 在 网 络 层 中 传输 的 是 数据 包 
(Packet， 又 称 分 组 ) ， 一 个 数据 包 是 一 个 数据 帧 经 过 网 络 层 协 议 重 封 
装 后 得 到 的 。 每 个 数据 包 的 包头 都 有 源 节 点 的 下 地 址 和 目的 节点 的 下地 
址 ， 网 络 间 的 寻 址 就 是 通过 IP 地 址 进行 的 。 在 网 络 间 的 通信 中 ， 在 网 
络 体系 结构 中 ， 数 据 是 自 上 而 下 传输 的 (从 网 络 层 到 物理 层 的 数据 单 


位 依次 是 包 、 帧 和 比特 ) ， 接 收 方 是 自 下 而 上 传输 的 (从 物理 层 到 网 
络 层 的 数据 单位 依次 是 比特 、 帧 和 包 ) ， 如 图 7-2 所 示 。 


由 数据 链 路 层 由 
发 送 方 路 由 器 接收 方 


图 7-2 不 同 网 络 间 主 机 通信 的 各 层 数据 传输 单位 


7.1.2 ”网 络 层 主 要 作用 


网 络 层 是 为 它 的 上 一 层 一 一 传输 层 服务 的 ， 并 接受 它 的 下 一 层 
一 一 数据 链 路 层 所 提供 的 服务 。 网 络 层 的 主要 作用 表现 在 以 下 几 个 方 
面 。 


(1) 屏蔽 网 络 差异 ， 提 供 透 明 传输 


因为 不 同 网 络 有 不 同 的 规范 要 求 ， 束 像 不 同城 市 有 不 同 的 交通 规 
范 一 样 。 网 络 层 就 古 为 了 解决 这 种 不 同 差 异 ， 寻 找 一 个 不 同 网 络 间 能 
共同 遵守 的 网 络 通信 规范 ， 以 便 不 同 网 络 间 能 相互 识别 ， 并 接受 对 方 
的 访问 请 求 。 这 样 传输 层 忠 可 以 在 不 同 网 络 间 进 行 透明 〈 也 吏 是 不 管 
不 同 网络 间 的 差异 ， 就 像 通信 双方 是 直接 互 连 一 样 ) 数据 传输 了 。 


网 络 层 癌 传输 层 提 供 的 服务 有 两 类 : 面向 连接 的 网 络 服务 和 无 连 
接 的 网 络 服务 。 虚 电路 服务 是 网 络 层 问 传输 层 提 供 的 一 种 面 问 连接 的 
服务 ， 是 可 以 使 所 有 数据 包 按 顺序 到 达 目 的 节点 的 可 靠 数据 传送 方 
式 。 在 虚 电 路 服务 中 ， 进 行 数据 交换 的 两 个 结 点 之 间 存 在 着 一 条 专 为 
它们 服务 的 虚 电 路 (相当 于 专线 连接 ， 或 者 点 对 点 连接 ) ， 无 须 附 加 
网 络 地 址 。 如 我 们 所 使 用 的 各 种 拨号 WAN 连 接 、 数 据 专线 等 接 入 方式 
都 是 属 于 面 问 连接 的 虚 电路 服务 方式 。 


数据 报 服务 是 网 络 层 提供 的 一 种 无 连接 的 网 络 服务 ， 只 能 提供 不 
可 靠 的 数据 传送 方式 ， 源 节点 (如 源 路 由 器 ) 发 送 的 每 个 数据 包 都 要 
附加 网 络 地 址 、 包 序号 等 信息 ; 目的 节点 收 到 的 数据 包 不 一 定 按 序 到 
达 ， 还 可 能 出 现 数据 包 丢失 的 现象 。IP 协 议 是 一 种 无 连接 的 网 络 层 协 
议 ， 提 供 无 连接 的 网 络 层 服务 。 


有 关 虚 电路 服务 和 数据 报 服务 都 将 在 本 章 后 面具 体 介绍 。 


(2) 为 网 络 间 通 信 提 供 路 由 选择 


路 由 选择 又 称 路 径 选择 ， 有 是 根据 一 定 的 原则 和 路 由 选择 算法 在 多 
个 结 点 的 通信 子 网 中 选择 一 条 到 达 目 的 节点 的 最 佳 路 径 的 过 程 。 确 定 
路 由 选择 的 策略 称 为 路 由 算法 。 在 无 连接 的 数据 报 服务 中 ， 网 络 结 点 
要 为 每 个 数据 包 做 出 路 由 选择 ， 整 像 你 到 达 男 个 一 个 城市 时 并 不 清楚 
该 市 的 交通 路 线 ， 所 以 只 能 在 中 转车 站 查看 对 应 的 交通 线路 来 查找 一 
个 到 达 你 要 去 的 目的 地 的 最 佳 线 路 ， 而 在 面向 连接 的 虚 电 路 服务 中 ， 
在 建立 连接 时 束 已 确定 了 路 由 路 径 ， 殉 像 你 坐 专车 直达 目的 地 一 样 ， 
根本 无 须 选 择 旅行 的 路 线 。 


(3) 数据 包 封 装 和 解 封装 


网 络 层 要 面临 数据 封装 和 解 封 疼 的 问题 ， 因 为 在 网 络 体系 结构 的 
不 同 层 次 中 传输 的 数据 单位 并 不 一 样 ， 且 在 发 送 方 数据 从 上 向 下 每 经 
过 一 层 都 必须 在 数据 头 部 添加 对 应 层 的 协议 头 和 (或 ) 协议 尾 信息 ， 


而 到 了 接收 方 时 ， 数 据 自 下 而 上 每 经 过 一 层 时 又 都 必须 解除 前 面 那 层 
所 封装 的 协议 头 和 (或 ) 协议 尾 信息 。 在 发 送 方 ， 来 自传 输 层 的 报 文 
通常 是 已 根据 对 应 网 络 链 路 的 MTU 〈 最 大 传输 单元 ) 被 分 为 多 个 数据 
段 ， 然 后 在 网 络 层 中 对 这 些 数据 段 尖 部 深 加 一 些 网 络 层 协议 控制 信息 
忠 组 成 了 数据 包 ， 这 就 是 包 的 封闭 过 程 。 数 据 包 的 头 部 包含 源 节 点 和 
目标 市 点 的 网 络 层 地 址 (如 IP 地 址 ) 。 在 接收 方 ， 数 据 从 低层 到 达 网 
络 层 时 ， 要 去 掉 在 数据 链 路 层 加 上 的 数据 链 路 层 协议 控制 信息 〈 也 惑 
古 帧 尖 和 帧 尾 ) ， 还 原 出 原来 的 数据 包 格式 ， 这 就 是 包 的 解 封装 过 
程 。 


(4) 拥塞 控制 


拥塞 控制 是 为 了 避免 网 络 传输 路 径 中 数据 的 传输 延迟 或 死 锁 。 在 
数据 链 路 层 我 们 提 到 了 流量 控制 功能 ， 那 是 针对 数据 链 路 中 点 对 点 传 
输 速 率 的 控制 ， 而 这 里 的 拥塞 控制 是 针对 在 网 络 传输 路 径 中 的 端 到 站 
传输 效率 的 控制 。 在 网 络 层 进行 拥塞 控制 时 主要 采用 预约 缓冲 区 、 许 
可 证 和 分 组 丢弃 等 方式 ， 具 体 将 在 本 章 后 面 介绍 。 


7.2 ”网 络 层 数 据 交 换 及 相关 技术 


数据 到 了 网 络 层 后 ， 路 由 器 是 如 何 把 这 些 数据 包 (或 数据 分 组 ) 
转发 到 位 于 另 一 网 络 中 的 目的 结 点 呢 ? 这 就 要 涉及 网 络 层 的 数据 交换 
技术 了 “。 从 整个 网 络 层 数据 交换 技术 的 发 展 来 看 ， 奖 换 扩 术 经 历 了 一 
个 由 线路 交换 、 报 文 交 换 到 现在 最 常用 的 分 组 交换 的 历程 。 报 文 交 换 
和 分 组 交换 部 属于 存储 -转发 交换 技术 。 


在 计算 机 网 络 中 ， 两 个 端点 之 间 通 常 需要 通过 中 间 结 点 实现 数据 
通信 ， 这 些 中 间 结 点 并 不 关心 数据 内 容 ， 只 提供 一 个 交换 设备 ， 把 数 
据 从 一 个 结 氮 转发 到 另 一 个 结扎 ， 直 至 达到 目的 病 。 数 据 交 换 技 术 主 
要 是 指 网 络 中 间 结 点 所 提供 的 数据 交换 功能 。 


7.2.1 ”线路 交换 


线路 交换 (Circuit Switching， 又 称 电路 交换 ) 是 最 原始 的 数据 交 
换 方 式 ， 是 在 网 络 中 利用 可 切换 的 物理 通信 线路 直接 连接 通信 双方 所 
进行 的 一 种 数据 交换 方式 。 最 闻 见 的 例子 是 电话 交换 系统 和 ISDN 


(Integrated Services Digital Network， 绽 合 业务 数字 网 ) 系统 。 


线路 交换 十 面 同 连接 的 服务 ， 两 人 台 计 算 机 通过 通信 子 网 进行 数据 
交换 之 前 ， 首 先 要 在 通信 子 网 中 建立 一 个 实际 的 物理 线路 连接 (通常 


由 一 种 开关 电路 来 控制 ， 如 图 7-3 所 示 ) 。 线 路 交换 的 最 主要 特点 就 是 
在 进行 数据 交换 前 需要 在 一 对 用 户 之 间 建 立 起 一 条 专用 的 数据 通路 ， 
在 整个 数据 传输 过 程 中 要 经 过 线路 建立 、 数 据 传输 与 线路 释放 这 三 个 


阶段 。 


图 7-3 线路 交换 物理 线路 连接 示意 图 


口 线路 建立 :通过 呼叫 完成 逐个 结 点 的 连接 过 程 ， 建 立 起 一 条 端 
到 端的 直通 物理 线路 。 

口 数据 传输 : 线路 建立 好 后 就 可 以 直接 在 端 到 端的 直通 线路 上 传 
输 数据 。 


口 线路 释放 : 数据 传输 完成 后 ， 由 任 一 用 户 同 交换 网 发 出 释放 请 
求 信 令 。 该 信 令 沿 通路 各 结 点 传送 ， 指 挥 这 些 结 点 拆除 对 应 的 链 路 ， 


以 释放 信道 贷 源 


图 7-4 列 出 了 线路 交换 的 三 个 主要 过 程 以 及 每 一 过 程 中 的 主要 步 
又 。 从 图 中 可 以 看 出 ， 在 线路 交换 方式 的 线路 建立 和 线路 释放 这 两 个 
主要 阶段 中 ， 都 需要 由 一 方 发 送 请 求 分 组 ， 然 后 另 一 方 确认 后 返回 应 
答 分 组 ， 这 十 一 个 二 次 握手 的 过 程 。 在 数据 传输 这 个 阶段 中 ， 一 方 也 
征 需要 返回 确认 应 答 的 ， 否 则 会 在 重 传 定 时 如 超时 后 重 传 对 应 的 数 
据 。 数 据 传输 部 分 与 传输 层 的 对 应 功能 类 似 ， 有 具体 参见 第 10 章 。 


图 7-4 线路 交换 的 三 个 主要 过 程 


线路 交换 方式 的 优点 是 : 通信 实时 性 强 ， 适 用 于 交互 式 会 话 类 通 
信 。 其 缺点 是 : 对 突 发 性 通信 不 适应 (因为 需 先 建立 好 的 物理 连 


接 ) ， 整 个 数据 交换 系统 效率 低 ， 系 统 也 不 具有 存储 数据 的 能 力 ， 很 
难 实现 拥塞 控制 。 


7.2.2 ”存储 -转发 


存储 -转发 (Store-and-forward) 从 其 名 字 就 可 以 看 出 ， 这 种 数据 交 
换 方式 是 网 络 结 点 运用 程序 先 将 途径 的 数据 流 按 传 输 单元 〈 可 以 是 报 
文 或 报 文 分 组 ) 接收 并 存储 下 来 ( 同 检 验 该 数据 单元 的 校 验 和 ) ， 一 
个 数据 单元 接收 完 后 根据 相关 的 路 由 算法 选择 一 条 合适 的 路 由 路 径 将 
数据 转发 出 去 ， 在 逻辑 (不 是 物理 线路 ) 上 为 数据 流 提 供 了 传输 通 
路 。 


存储 -转发 交换 方 式 与 线路 交换 方式 相 比 具有 如 下 特点 : 


口 发 送 的 数据 要 与 目的 地 址 、 源 地 址 、 控 制 信息 一 起 按照 一 定格 
式 组 成 一 个 数据 单元 〈 报 文 或 报 文 分 组 ) 进入 通信 子 网 ， 如 图 7-5 所 


修 ° 


b) 分 组 结构 


图 7-5 报 文 及 报 文 分 组 结构 


说 明 ”数据 通过 通信 子 网 传输 时 可 以 有 报 文 “message) 与 报 文 分 
组 (packet) 两 种 方式 。 报 文 传输 方式 是 不 管 发 送 数据 的 长 度 是 多 少 ， 
都 把 它 当 作 一 个 逻辑 单元 发 送 ; 报 文 分 组 传输 方式 是 限制 一 次 传输 数 
据 的 最 大 长 度 ， 如 果 传 输 数 据 超过 规定 的 最 大 长 度 ， 发 送 结 点 就 将 它 
分 成 多 个 报 文 分 组 发 送 。 


由 于 报 文 分 组 长 度 较 短 ， 所 以 在 传输 出 错时 检 错 容易 并 且 重 发 伦 
费 的 时 间 较 少 ， 另 外 ， 由 于 限定 分 组 最 大 数据 长 度 ， 有 利于 提高 存储 - 
转发 结 点 的 存储 空间 利用 率 与 传输 效率 。 公 用 数据 网 采用 的 是 分 组 区 
换 技术 。 但 要 注意 ， 在 报 文 分 组 中 也 有 两 种 格式 ， 原 始 的 分 组 是 不 带 
地 址 信息 字段 的 ， 而 数据 报 分 组 是 市 地 址 信息 字段 的 。 所 以 图 7-5b 更 准 
确 地 讲 是 数据 报 分 组 格式 。 


口 通 信子 网 中 的 结 点 是 通信 控制 处 理 机 (如 路 由 器 、 三 层 交 换 
机 ) ， 其 负责 完成 数据 单元 的 接收 、 差错 校 验 、 存 储 、 路 选 和 转发 功 


存储 -转发 数据 交换 方式 的 优点 如 下 : 


口 通 信子 网 中 通信 控制 处 理 机 具有 路 由 功能 ， 可 以 动态 选择 报 文 
分 组 通过 通信 子 网 的 最 佳 路 径 ; 


口 可 以 有 效 地 进行 拥塞 控制 ， 提 高 端 到 端 系统 传输 效率 ; 


口 数据 单元 在 通过 通信 子 网 中 的 每 个 通信 控制 处 理 机 时 ， 均 要 进 
行 差 错 检 查 与 纠 错 处 理 ， 因 此 可 以 减少 传输 错误 ， 提 高 系统 可 徘 性 ; 


口 通过 通信 控制 处 理 机 可 以 对 不 同 通 信 速 率 的 线路 进行 转换 ， 也 
可 以 对 不 同 的 数据 代码 格式 进行 变换 。 


根据 所 传输 的 数据 单元 征 报 文 还 是 报 文 分 组 ， 人 存储- 转发 交换 方式 
又 可 细 分 报 文 交换 和 分 组 交换 两 种 ， 下 面具 体 介绍 。 


1. 报 文 交 换 


报 文 交换 (Message Switching) 是 指 信 息 以 报 文 (Message， 完 整 
数据 的 一 个 信息 段 ) 为 单位 进行 存储 -转发 的 一 种 数据 交换 方式 。 在 报 
文 交 换 方 式 中 ， 报 文 是 网 络 中 交换 与 传输 的 数据 单元 ， 即 站 扣 一 次 性 
要 发 送 的 数据 块 ， 其 包含 了 将 要 发 送 的 完整 的 数据 信息 ， 其 长 短 可 能 
不 一 致 ， 长 度 不 限 且 可 变 。 所 请 存储 -转发 是 当 报 文 到 达 路 由 器 后 先 存 
储 起 来 ， 等 行路 由 右 分 配 资 源 再 进行 数据 分 组 的 转发 。 


报 文 交换 的 原理 是 用 户 发 送 的 数据 不 是 直接 发 送 给 目的 让 点 的 ， 
而 是 先 在 中 间 结 点 上 进行 缓存 (这 类 中 间 结 点 通常 是 由 具有 存储 能 
的 交换 机 、 路 由 器 承担 ) ， 然 后 再 由 中 间 结 点 在 线路 空间 时 把 数据 发 
送出 去 。 如 图 7-6 所 示 的 是 一 个 报 文 交 换 示例 。 其 中 中 间 结 点 1 十 用 来 绥 
存 站 点 A 发 送 的 数据 的 ， 而 中 间 绪 点 3 是 用 来 缓存 站 点 B 发 送 的 数据 
的 。 
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图 7-6 报 文 存储 转发 示例 1 


报 文 交换 无 须 同时 占用 整个 物理 线路 。 如 果 一 个 站 点 希望 发 送 一 
个 报 文 ， 束 将 目的 地 址 附加 在 报 文 上 ， 然 后 将 整个 报 文 传递 给 中 间 结 
点 ; 中 间 结 点 暂 存 报 文 ， 根据 地 址 确定 输出 端口 和 线路 ， 排 队 等 竺 ， 
当 线 路 至 朵 时 再 笑 公 给 下 一 搞 扎 ， 直 全 终局 。 


目前 在 多 数 情况 下 网 络 中 的 每 个 结 点 都 有 存储 功能 ， 都 可 以 将 完 
整地 接收 的 报 文 完 暂 存 起 来 ， 然 后 将 报 文 发 送 到 下 一 个 更 接近 目的 主 
机 的 结 点 中。 如 此 操作 ， 直 至 将 报 文 发 送 到 目的 主机 为 止 。 由 此 可 以 
看 出 ， 它 采用 的 吏 是 数据 报 服务 方式 。 图 7-7 所 示 的 是 另 一 个 报 文 存储 
转发 示例 ， 报 文 首先 由 源 主机 HA 发 出 ， 到 达 最 近 的 路 由 善 R3，R3 边 接 
收 边 存 储 ， 行 全 部 接收 完 后 R3 再 根据 路 由 选择 把 该 报 文 转发 到 R4，R4 
同样 采取 存 取 - 转 发 方式 ， 然 后 再 根据 路 由 选择 把 该 报 文 转发 到 R5，R5 
采取 同样 的 方式 ， 最 终 把 报 文 一 一 转发 到 目的 主机 HB 。 


分 组 交换 (Packet Switching， 也 就 是 包 交 换 ) 技术 。 在 分 组 交换 
技术 中 有 两 大 技术 派系 : 一 种 是 采用 路 由 技术 〈 也 有 是 目前 比较 普遍 采 
用 的 一 种 交换 方式 ) ， 在 要 转发 的 数据 包头 部 加 上 源 市 点 和 目的 和 点 


的 IP 地 址 ， 然 后 通过 路 由 技术 一 级 级 地 把 数据 转发 下 去 。 这 种 分 组 交 
换 拉 术 束 是 通常 所 说 的 数据 报 服务 ， 其 中 的 分 组 称 为 数据 报 


(Datagram) 。 


男 一 种 是 不 依靠 路 由 技术 ， 而 是 在 进行 数据 分 组 转 前 先 在 源 市 点 
和 目的 节点 间 的 所 有 路 由 器 间 建 立 一 条 虚拟 的 通信 通道 ， 然 后 再 把 数 
据 分 组 从 这 个 虚拟 通道 中 转发 到 目的 太 点 。 这 种 分 级 交换 技术 就 十 虚 
电路 服务 ， 所 建立 的 虚拟 通道 称 为 “ 虚 电 路 ” (Virtual Circuit，VC) 。 


采用 虚 电 路 方式 进行 分 组 交换 的 典型 实例 就 是 通过 ADSL 拨 号 连接 ISP 
网 络 (我 们 并 不 需要 配置 好 到 达 ISP 网 络 的 路 由 ) ， 在 配置 时 我 们 就 要 
配置 好 ISP (Internet 服 务 商 ) 的 VC 值 。 


分 组 交换 是 结合 报 文 区 换 和 线路 交换 两 种 交换 方式 的 优点 而 新 开 
发 的 一 种 数据 交换 方式 。 分 组 交换 也 采用 报 文 交换 的 存储 -转发 机 制 ， 
但 是 规定 了 传输 数据 的 单位 长 度 ， 过 长 的 报 文 被 分 成 较 小 的 单位 
(Packet， 分 组 ) ， 依 次 发 送 。 现 在 主要 采用 这 种 数据 交换 方式 。 


通过 前 面 的 介绍 我 们 已 经 知道 ， 每 个 报 文 会 有 完整 的 发 送信 息 ， 
包括 源 和 目的 地 址 ， 但 是 如 来 把 一 个 报 文 分 成 了 儿 个 分 组 ， 这 些 中 间 
的 分 组 肯定 是 不 会 包含 有 完整 的 发 送信 息 的 ， 那 这 些 分 组 又 是 如 何 正 
确 传 输 的 呢 ? 这 时 就 要 根据 上 区 介绍 的 两 种 服务 方式 来 选择 了 : 通过 
数据 报 这 种 服务 方式 为 每 个 分 组 都 添加 了 报 文 号 、 分 组 号 、 目 的 地 
址 、 源 地 址 和 校 验 字 段 信 息 (如 图 7-5b 所 示 ) ， 然 后 将 这 些 信 息 发 送出 
去 ， 由 通信 子 网 中 的 结 点 进行 路 由 选择 。 在 一 个 报 文 的 所 有 分 组 到 达 
了 目的 主机 后 ， 再 将 各 个 分 组 按照 序号 编排 起 来 。 


采用 虚 电路 这 种 服务 方式 的 分 组 无 须 淆 加 源 和 目的 地 址 信息 ， 但 
仍 需要 添加 报 文 号 、 分 组 号 信息 ， 因 为 在 发 送 任何 分 组 之 前 ， 首 先 在 
发 送 主机 和 目的 主机 之 间 建 立 一 条 逻辑 连接 (也 就 是 建立 一 条 虚 电 
路 ， 无 须 进 行路 径 选 择 ) ， 然 后 所 有 的 分 组 都 将 按照 顺序 依次 被 发 送 
到 目的 主机 。 在 所 有 的 分 组 都 发 送 之 后 ， 虚 电路 将 被 拆除 。 每 台 主 机 


可 以 和 男 一 台 主 机 建立 若干 个 虚 电 路 ， 每 台 主 机 也 可 以 同时 和 才干 台 
主机 建立 虚 电 路 。 


有 天 数据 报 和 虚 电 路 这 两 种 服务 方式 将 在 下 面 两 入 具体 介绍 。 


7.23 局 电路 个 骨 区 换 


上 节 已 介绍 了 ， 在 分 组 交换 中 又 有 两 种 可 选 的 工作 方式 ， 那 就 是 
数据 报 方 式 和 虚 电 路 方式 ， 对 应 向 传输 层 提供 数据 报 服务 和 虚 电 路 服 
务 。 对 于 面向 连接 的 服务 《如 拨号 通信 ) 则 需要 采用 虚 电 路 服务 进行 
分 组 交换 。 就 像 数 据 链 路 层 在 传输 数据 前 需要 先 建立 链 路 连接 一 样 ， 
在 虚 电 路 分 组 交换 中 ， 分 组 被 发 送 之 前 ， 必 须 在 发 送 方 与 接收 方 之 间 
建立 一 条 专用 的 逻辑 连接 〈 虚 电路 ，VC) ， 并 且 以 一 个 在 所 有 经 过 的 
节点 或 结 点 上 均 唯 一 的 虚 电 路 标识 符 (Virtual Circuit Identifier，VCD) 
进行 标识 。 这 条 VC 所 代表 的 就 是 所 有 经 过 的 节点 和 结 点 的 串 连 。 


从 某 个 结 点 到 其 他 结 点 间 可 能 有 无 数 条 虚 电路 存在 ， 用 于 文 持 这 
两 个 端 系统 之 间 的 不 同 数据 传输 。 一 个 结 点 也 可 以 同时 与 多 个 结 点 之 
间 具 有 虚 电路 ， 每 条 虚 电 路 文 持 特 定 的 两 个 结扎 之 间 的 数据 传输 。 在 
虚 电 路 分 组 交换 中 ， 为 了 进行 数据 传输 ， 网 络 的 源 节 点 和 目的 节操 之 
间 要 先 建 一 条 逻辑 通路 。 每 个 分 组 除了 包含 数据 内 容 外 ， 还 包含 一 个 
虚 电 路 标识 符 。 在 预先 建 好 的 路 径 上 的 每 个 结 点 都 知道 把 这 些 分 组 引 
导 到 哪里 去 ， 不 再 需要 路 由 选择 判定 。 最 后 ， 由 某 一 个 站 用 清除 请 求 


分 组 来 结束 这 次 连接 。 


在 图 7-8 所 示 的 示例 中 建立 了 四 条 虚 电 路 ， 分 别 用 于 PC1 与 PC3， 
PC1 与 PC4、PC2 与 PC3、PC2 与 PC4 的 通信 ， 它 们 所 对 应 的 VC 分 别 是 
PC1-R1-PC3 ~ PC1-R1-R3-PC4 、 PC2-R2-R1-PC3 、 PC2-R2-R3-PC4 。 
每 条 VC 创建 后 均 以 所 有 经 过 的 节点 和 结 点 唯一 的 标识 符号 (从 1 开 
始 ) 自动 创建 一 个 VC 号 。 
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7-8 “ 虚 电 路 ”示例 


在 如 图 7-8 所 示 的 示例 中 ， 假 设 R1 中 已 创建 了 从 PC1 到 PC3 以 及 从 
PC2 到 PC3 这 两 条 VC， 并 且 所 分 配 的 VC 号 分 配 为 VC1、VC2。R3 中 已 
创建 一 条 由 PC2 到 达 PC4 的 VC， 假 设 标识 为 VC3。 如 果 PC1 再 要 通过 
R1、R3 创 建 一 条 到 达 PC4 的 VC， 那 么 ， 尽 管 PC1 中 当前 只 有 一 条 


VC1， 但 是 R1 中 已 有 两 条 VC， 即 VC1 和 VC2，R4 中 也 只 有 一 条 VC， 
即 VC3， 但 是 此 时 所 新 建 的 VC 号 只 能 大 于 3 (如 VC4、 

VCD won ) ， 因 为 在 新 建 的 VC 路 径 中 各 节点 和 结 点 已 用 到 了 VC1、 
VC2、VC3 这 三 个 标识 待 。 返 程 应答 路 径 与 数据 发 送 路 径 相 反 ， 但 仍 
是 采用 同一 条 VC 通道 进行 传输 ， 如 PCI1 癌 PC4 发 送 数据 的 VC 路 径 是 
PC1-R1-R3-PC4， 假 设 所 分 配 的 VC 标识 符号 为 VC1， 而 PC4 疝 PC1 应 答 
的 信息 传输 路 径 为 PC4-R3-R1-PC1， 但 仍 使 用 VC1 这 条 虚拟 通道 。 


在 虚 电 路 分 组 交换 中 ， 一 次 通信 的 所 有 分 组 都 通过 所 创建 的 这 条 
虚 电 路 路 径 进行 传输 〈 而 不 会 像 在 数据 报 分 组 交换 中 ， 不 同 分 组 可 能 
沿 不 同 路 由 路 径 进行 传输 ) ， 分 组 也 不 必 带 目的 地 址 、 源 地 址 等 辅助 
信息 。 而 且 ， 虚 电路 交换 方式 与 线路 交换 方式 类 似 ， 在 开始 进行 数据 
交换 前 ， 也 是 需要 先 建 立 好 线路 连接 ， 只 不 过 线路 交换 中 建立 的 是 物 
理 连 接 ， 而 在 虚 电路 交换 中 建立 的 是 逻辑 连接 。 


整个 虚 电 路 交换 过 程 分 为 以 下 三 个 阶段 : 虚 电 路 建立 、 数 据 传输 
与 虚 电 路 释放 。 整 个 过 程 可 参见 图 7-4 所 示 ， 只 不 过 此 处 首先 建立 的 是 
虚 电 路 连接 ， 而 不 是 物理 连接 ， 另 外 ， 所 发 送 的 不 是 整个 数据 报 ， 而 
征 报 文 分 组 。 


(1) 建立 虚 电 路 


网 络 的 源 节 点 和 目的 节点 之 间 要 先 建立 一 条 逻辑 通路 。 在 图 7-8 所 
示 的 示例 中 ， 假 设 PC1 有 一 个 或 多 个 报 文 要 发 送 到 PC4 去 ， 那 么 PC1 首 
先 要 发 送 一 个 呼叫 请 求 分 组 到 结 点 R1， 请 求 建立 一 条 到 节点 PC4 的 连 
接 。 结 点 R1 根 据 它 的 拓扑 连接 情况 确定 到 达 目 的 节点 PC4 最 佳 下 一 个 
结 点 为 R3， 与 之 建立 起 逻辑 连接 后 把 来 目 PC1 的 呼叫 请 求 分 组 转发 给 
R3， 结 点 R3 最 终 把 呼叫 请 求 分 组 转发 到 目的 节点 PC4。 如 果 PC4 准 备 
接收 这 个 连接 请 求 ， 就 发 送 一 个 呼叫 应 答 分 组 到 结 点 R3， 然 后 通过 上 
述 相反 路 径 把 呼叫 应 答 分 组 通过 结 点 R1 返 回 到 PC1。 这 样 就 在 源 节点 
PC1 和 目的 节点 PC4 之 间 建 立 起 了 一 条 逻辑 通路 PC1-R1-R3-PC4， 然 后 
根据 这 条 路 径 中 所 有 节点 和 结 点 中 已 分 配 的 VC 标签 的 情况 ， 为 该 条 新 
建 的 VC 分 配 一 个 对 于 路 径 中 各 节点 和 结 点 均 唯 一 的 VC 标识 符 ， 完 成 
虚拟 电路 建立 过 程 。 


(2) 传输 数据 


在 逻辑 通路 建立 好 后 ， 束 可 以 在 虚 电 路 上 交换 数据 了 。 每 个 分 组 
除了 包含 数据 部 分 外 ， 还 包含 所 采用 的 VC 号 ， 这 样 既 可 以 确保 这 些 分 
组 选择 正确 的 VC 通道 进行 数据 交换 ， 又 可 以 使 各 结 点 识别 这 些 分 组 是 
否 属 于 同一 次 通信 内 容 。 然 后 根据 这 个 VC 号 所 对 应 的 路 径 把 这 数据 分 
组 依次 传送 到 目的 和 节点， 不 再 需要 进行 路 径 选择 。 


(3) 拆除 虚 电 路 


当 本 次 数据 全 部 传输 完 后 ， 其 中 任意 一 个 结 点 均 可 发 送 拆除 虚 电 
路 的 请 求 分 组 来 结束 这 次 连接 ， 其 他 结 点 收 到 这 个 分 组 后 立即 终止 当 
前 所 用 的 这 条 虚 电 路 ， 释 放 该 条 虚 电 路 所 占用 的 系统 资源 。 


综 上 所 述 可 以 得 出 ， 虚 电路 分 组 交换 方式 具有 以 下 几 个 主要 特 


口 在 每 次 分 组 交换 前 ， 必 须 在 发 送 方 与 接收 方 之 间 建 立 一 条 逻辑 


口 一 次 通信 的 所 有 分 组 都 通过 这 条 虚 电 路 顺序 传送 ， 也 束 相 当 于 
有 固定 的 交换 路 径 ， 所 以 每 个 分 组 均 不 必 带 目的 地 址 、 源 地 址 等 信 
= 


BY 


口 分 组 通过 虚 电 路 上 的 每 个 结 点 时 ， 结 点 只 需要 做 差错 检测 (做 
校 验 和 检测 ) ， 而 不 需要 做 路 径 选 择 。 


口 通信 子 网 中 每 个 结 点 可 以 和 任何 结 点 建立 多 条 虚 电 路 连接， 每 
条 物理 线路 可 以 建立 无 数 条 虚 电路 连接 ， 每 条 虚 电 路 文 持 特 定 的 两 个 
结 点 之 间 的 数据 传输 。 


7.2.4 数据 报 分 组 交换 


分 组 交换 除了 上 市 介绍 的 虚 电 路 交换 方式 外 ， 还 有 一 种 应 用 更 为 
普 衣 的 数据 报 交 换 方 式 。 在 虚 电 路 分 组 交换 方式 中 ， 分 组 数据 是 通信 
逻辑 虚 电 路 信道 进行 传送 的 ， 而 在 数据 报 分 组 交换 方式 中 ， 每 个 分 组 
数据 均 被 视 为 一 个 数据 报 ， 可 以 单独 通过 路 由 路 径 发 送 ， 无 须 先 创建 
传送 的 虚 电 路 ， 但 网 络 结 点 要 为 每 个 数据 报 做 独立 的 路 由 选择 。 


在 这 里 首 爷 要 搞 清 楚 什么 是 数据 报 。 其 实数 据 报 就 是 在 数据 前 部 
增加 了 源 地 址 和 目的 地 址 信息 字段 的 报 文 分 段 ， 可 以 作为 独立 的 数据 
进行 传输 。 因 为 每 个 数据 报 目 身 携 沉 有 足够 的 信息 ， 其 中 包括 产地 
址 、 目 的 地 址 、 结 点 间 的 路 由 信息 等 ， 数 据 报 的 发 送 束 是 通过 这 些 地 
址 和 路 由 信息 来 保证 数据 准确 发 送 到 目的 节点 的 。 一 个 结 点 接收 到 一 
个 数据 报 后 ， 根 据 数 据 报 中 的 地 址 信息 和 结 点 所 存储 的 路 由 信息 ， 找 
出 一 个 合适 的 出 路 ， 把 数据 报 原样 发 送 到 下 一 个 结 点 。 


数据 报 操 作 方式 的 数据 发 送 原理 如 下 : 


1) 当 某 个 端 系 统 要 发 送 报 文 时 ， 先 将 报 文 拆 成 若干 个 带 有 序号 和 
地 址 信息 的 数据 报 ， 然 后 依次 发 给 网 络 结 上 后。 


2) 各 结 点 可 根据 数据 报 中 所 包括 的 地 址 和 路 由 信息 ， 选 择 不 同 的 
路 由 路 径 进 行 发 送 。 另 外 ， 各 个 结 点 也 可 能 随时 根据 网 络 的 流量 、 故 


障 等 情况 选择 最 佳 路 径 。 


在 这 种 交换 方式 中 ， 各 数据 报 各 行 其 道 ， 很 难保 证 全 部 按 顺序 到 
达 目 的 市 点 ， 有 些 数 据 报 甚至 还 可 能 在 途中 丢失 。 图 7-9 所 示 的 束 古 不 
同 数据 报 沿 不 同 路 径 传输 的 示例 。 从 主机 A 要 发 送 到 相同 目的 节操 一 一 
主机 B 的 两 个 数据 报 D1、D2 沿 着 不 同 路 径 进行 传输 。 当 然 ， 只 是 可 以 
这 么 做 ， 并 不 是 说 数据 报 分 组 交换 中 每 个 数据 报 必 须 走 不 同 的 路 径 。 


图 7-9 不 同 数据 报 沿 不 同 路 径 进行 交换 的 示例 


在 数据 报 分 组 交换 方式 中 ， 分 组 传送 之 前 不 需要 预先 在 源 主机 与 
目的 主机 之 间 建 立 线 路 连接 ， 只 需 根据 结 点 通信 主机 《如 路 由 器 、 三 
层 交 换 机 ) 所 创建 的 路 由 信息 为 不 同 的 数据 报 选 择 相同 或 不 同 的 传输 
路 径 。 也 就 是 说 源 主机 所 发 送 的 每 一 个 数据 报 分 组 都 可 以 独立 地 选择 


| 


一 条 传输 路 径 ， 同 一 源 主机 发 送 的 不 同 分 组 在 通信 子 网 中 可 能 通过 不 
同 的 传输 路 径 ， 不 按 顺序 到 达 同 一 个 目的 主机 。 


因为 数据 报 分 组 交换 无 须 为 每 次 通信 建立 单独 的 逻辑 连接 ， 所 以 
数据 交换 效率 较 高 ， 特 别 适 用 于 突 发 性 通信 。 但 由 于 每 一 个 分 组 在 传 
输 过 程 中 都 必须 带 有 目的 地 址 与 源 地 址 ， 所 以 有 效 数据 的 传输 率 比 较 
低 ;， 另 外， 因为 数据 报 分 组 每 经 过 一 个 结 点 都 要 根据 路 由 算法 选择 最 
佳 路 由 路 径 ， 所 以 数据 报 方式 报 文 传输 延迟 较 大 ， 不 适用 于 长 报 文 、 


会 话 式 通信 。 


7.2.5 虚 电 路 交换 和 数据 报 交 换 的 比较 

为 了 正确 理解 虚 电路 交换 和 数据 报 交换 这 两 种 不 同 的 分 组 交换 广 
式 ， 本 节 将 从 各 方面 对 它们 进行 比较 。 

(1) 传输 方式 上 的 区 别 


虚 电 路 交换 方式 需 在 源 、 目 的 主机 之 间 正 式 进 行 数据 交换 前 建立 
逻辑 连接 ;通信 完成 后 ， 又 需要 释放 对 应 的 逻辑 连接 。 而 在 数据 报 区 
换 方式 中 ， 无 须 移 建立 连接 (当然 也 无 需 释放 连接 ) ， 直 接 根据 路 由 
信息 进行 数据 交换 。 


(2) 数据 格式 的 区 别 


虚 电 路 交换 方式 仅 在 源 主机 发 出 呼叫 分 组 中 需要 填 上 源 和 目的 主 
机 的 IP 地 址 ， 在 数据 传输 阶段 ， 各 分 组 都 只 需 填 上 虚 电 路 号 〈 也 就 是 
VC 号 ) 和 分 组 号 。 而 数据 报 交 换 方 式 ， 由 于 每 个 数据 报 都 单独 传送 ， 
因此 在 每 个 数据 报 中 都 必须 添加 源 和 目的 主机 的 IP 地 址 ， 以 便 网 络 结 
扩 根 据 对 应 的 路 由 信息 同 目 的 主机 转发 ， 这 在 频 脸 的 人 -机 交互 通信 应 
用 中 不 是 很 适用 ， 也 降低 了 信道 的 利用 率 。 


(3) 转发 路 径 的 区 别 


虚 电 路 交换 方式 同一 次 通信 的 每 个 分 组 都 会 沿 着 同样 的 路 径 进行 
转发 ， 也 无 须 进 行路 径 选 择 。 在 数据 报 交 换 中 ， 每 个 数据 报 每 经 过 一 
个 网 络 结 点 都 要 进行 一 次 路 径 选择 ， 而 且 同 一 报 文 所 分 出 的 多 个 报 文 
分 组 所 采用 的 转发 路 径 也 可 能 不 一 样 。 


(4) 可 靠 性 方面 的 区 别 


在 虚 电 路 交换 方式 中 ， 由 于 从 源 主机 发 出 的 所 有 分 组 部 是 通过 事 
先 建立 好 的 一 条 虚 电 路 进行 传输 的 ， 所 以 能 保证 分 组 按 发 送 顺 序 到 达 
目的 主机 ， 且 目的 主机 每 收 到 一 个 分 组 后 需要 回 源 主机 应 答 确 认 ， 可 
靠 性 高 。 但 在 数据 报 交 换 方式 中 ， 当 需要 把 一 份 长 报 文 分 成 者 干 个 短 
的 数据 报 分 组 时 ， 由 于 它们 都 是 被 独立 传送 的 ， 还 可 以 各 目 通过 不 同 
的 路 径 到 达 目 的 主机 ， 因 此 不 能 保证 这 些 数据 报 分 组 按 序 列 到 达 目 的 
主机 。 再 加 上 这 种 交换 方式 的 目的 节点 在 收 到 数据 报 后 也 不 需 发 送 确 
认 ， 所 以 可 徘 性 较 低 。 


(5) 适应 性 方面 的 区 别 


在 虚 电 路 交换 方式 中 ， 当 传输 途中 的 某 个 结 点 或 链 路 发 生 故 障 
时 ， 必 须 重 新 建立 虚 电 路 才能 进行 通信 。 而 在 数据 报 交 换 方式 中 ， 可 
以 绕 开 这 些 故 障 地 区 男 选 其 他 路 由 路 径 ， 快 速 地 把 数据 传 至 目的 地 。 
因此 数据 报 交 换 比 虚 电 路 交换 的 适应 性 更 强 。 


(6) 拥塞 控制 能 力 方面 的 区 别 


在 数据 报 区 换 方式 中 ， 中 间 结 点 可 为 数据 报 选择 一 条 流量 较 小 的 
路 由 路 径 ， 避 开 流 量 较 高 的 路 径 ， 因 此 数据 报 交换 方式 既 可 以 平衡 网 
络 中 的 信息 流量 ， 又 可 使 数据 报 得 以 更 迅速 地 传输 。 而 在 虚 电 路 交换 
方式 中 ， 一 旦 虚 电 路 建立 后 ， 中 间 结 点 是 不 能 根据 流量 情况 来 改变 分 
组 的 传送 路 径 的 ， 所 以 拥塞 控制 能 力 较 差 。 


综 上 所 述 ， 虚 电路 交换 方式 和 数据 服 交 换 方 式 各 有 优 、 和 缺点 ， 综 
合 比 较 如 表 7-1 所 示 。 


表 7-1 数据 报 和 虚 电路 交换 方式 比较 


I ET 


添加 地 址 信息 。 | ”每 个 分 组 都 有 源 和 目的 IP 地 址 ”| ”无 需 人 p 地 址 信息 ， 但 需 加 上 虚 电路 标识 符 
ee 邓 每 不 分 组 儿 立 进行 ， 不 同 分 绝 | ” 轨 碟 电路 建 好 时 ， 路 由 就 已 确定 ， 所 有 分 组 部 经 过 下 

Se 的 路 由 路 径 可 能 不 同 路 由 进行 交换 

除了 : 月 渡 < 人 失 分 旨 外 ， > 其 i lt \ AU 日 曲目 nD a 

结 点 失效 的 影响 | (如同 二 全 分 各 人 大。 | 所 有 经 过 失效 路 由 器 的 此 虚 电路 都 要 被 终 上 
数据 传输 效率 高 

二 加 末 有 足够 玖 强 证 区 分 配给 已 经 建立 的 三 东 度 电 路， 
I 1 
i ee 人 机 交互 比较 颇 篆 ， 可 靠 性 要 求 高 的 应 用 环境 ， 如 语 


音 通信 


7.3 ”网 络 层 协议 及 报 文 格式 


在 TCP/IP 体 系 结构 的 网 际 互 连 层 ， 最 重要 的 协议 就 是 IP 协 议 簇 。 
目前 主流 的 了 Pv4 协 议 复 中 包括 了 三 个 协议 : 卫 (Internet Protocol， 因 特 
网 协议 ) 、ARP (Address Resolution Protocol， 地 址 解析 协议 ) 、 
ICMP (Internet Control Message Protocol， 因 特 网 控制 消息 协议 ) 。 
IPv6 协 议 复 中 包括 了 四 个 协议 : IPv6、ICMPv6、ND (Neighbor 
Discovery， 邻 居 发 现 ) 协议 和 MLD (Multicast Listener Discover， 组 播 
侦 听 器 发 现 ) 协议 。 本 节 将 分 别 对 这 些 协议 及 它们 的 报 文 格式 进行 具 


体 介绍 。 
7.3.1 ”IP 协议 基本 功能 


目前 的 计算 机 网 络 ， 特 别 是 TCP/IP 网 络 ， 使 用 最 多 的 是 数据 报 分 
组 交换 方式 ， 而 卫 协 议 是 用 于 将 多 个 分 组 交换 网 络 和 连接 起 来 的 最 典型 
通信 协议 。HP 协 议 是 一 个 无 连接 的 服务 ， 负 责 在 源 地 址 和 目的 地 址 之 
间 传 送 数据 报 ， 然 后 为 了 适应 不 同 网 络 对 分 组 大 小 的 要 求 ， 需 要 对 上 
层 传 来 的 报 文 进行 分 割 ， 最 后 调用 本 地 网 络 协 议 将 数据 报 传送 给 下 一 
个 网 关 或 目的 计算 机 。 经 过 十 几 年 的 发 展 ， 目 前 最 新 的 IP 协 议 的 版 本 
为 IPvV6， 不 过 现在 主流 使 用 的 仍 是 IPv4 。 


IP 协 议 的 主要 功能 束 古 把 数据 报 在 互 连 的 网 络 上 传送 ， 将 数据 报 
在 一 个 个 IP 模 块 间 传 送 直 到 传送 到 目的 模块 。 网 络 中 每 个 主机 和 网 关 
上 都 有 IP 模 块 。 数 据 报 在 一 个 个 模块 间 通 过 路 由 人 处理 网 络 地 址 传送 到 
目的 地 址 。 具 体 来 说 ，IP 协 议 主 要 有 以 下 几 方 面 的 功能 


通过 第 6 草 的 学 习 我 们 已 经 知道 ， 在 同一 以 太 局 域 网 内 部 ， 结 点 间 
的 寻 址 可 以 通过 二 层 MAC 地 址 进行 ， 但 在 不 同 网 络 之 间 ， 是 不 能 通过 
MAC 地 址 的 ， 因 为 用 于 MAC 地 址 寻 址 的 广播 帧 只 能 在 同一 个 以 太 网 
段 内 部 进行 ， 不 能 在 不 同 网 段 内 传播 。 在 不 同 网 络 中 只 能 通过 三 层 地 
址 进行 寻 址 ， 束 像 在 一 个 国家 范围 内 不 能 通过 人 的 名 字 来 查找 一 个 
人 ， 而 必须 通过 身份 证 来 查找 一 样 。 因 为 同名 的 人 可 能 非常 多 ， 但 每 
个 人 的 身份 证 是 唯一 的 。 当 然 对 于 不 同 协议 的 网 络 ， 三 层 协议 也 不 一 
样 ， 如 在 常用 的 IP 网 络 中 运行 的 三 层 协议 就 是 IP 协 议 ， 对 应 的 三 层 地 
址 就 是 IP 地 址 ， 而 在 以 前 的 Netware IPX/SPX (Internetwork Packet 


eXchange/Sequences Packet eXchange， 网 际 包 交 换 / 顺 序 包 交 换 ) 网 络 
中 三 层 协议 瓯 是 IPX 地 址 。 


有 关 IPv4 和 IPv6 地 址 方面 的 知识 将 在 第 8 草 具 体 介绍 。 


(2) 数据 报 的 封装 


在 卫 网 络 中 ， 从 传输 层 到 达 的 数据 段 都 需要 经 过 IP 协 议 进行 重新 
封装 的 。 因 为 协议 是 无 连接 的 服务 ， 并 且 采 用 数据 报 交 换 方式 ， 所 
以 封装 后 形成 的 是 了 数据 报 。IP 封 装 的 目的 区 是 标识 此 IP 数 据 报 发 送 
节操 和 接收 市 点 的 IP 地 址 及 控制 信息 。 有 关 IP 数 据 报 的 格式 将 在 本 章 
后 面具 体 介绍 。 


(3) 分 段 与 重组 


不 同 网 络 上 的 链 路 可 以 传输 的 最 大 报 文大 小 是 不 同 的 ， 这 就是 我 
们 通常 所 说 的 MTU (最 大 传输 单元 。 为 了 使 我 们 要 传输 的 数据 报 能 
在 不 同 网 络 中 传输 ， 当 一 些 尺 寸 较 大 的 数据 报 要 在 某 个 MTU 值 比较 小 
的 网 络 链 路 上 传输 时 惑 可 能 需要 对 原来 的 数据 报 进行 拆 分 ， 形 成 一 个 
个 小 的 分 段 ， 然 后 再 把 这 些 分 段 依次 传输 出 去 。 这 吏 是 了 协议 的 分 段 
功能 。 有 既然 在 发 送 节 后 对 原来 的 数据 报 进行 了 拆 分 ， 在 接收 市 点 目 然 
束 面 临 了 一 个 如 何 把 这 些 被 拆 分 的 分 段 重 新 组 合 起 来 ， 还 原 成 原来 的 
大 的 数据 报 的 问题 ， 这 了 束 是 PP 协议 的 分 段 重组 功能 。 


7.3.2 ”IPv4 的 不 足 


IPv4 目 1981 年 发 布 RFC791 后 就 没有 什么 更 改 。 虽 然 IPv4 极 无 数 实 
践 证 明 是 可 靠 、 易 于 实现 和 可 交互 的 ， 并 且 经 受 住 了 各 种 考验 ， 但 时 
至 今天 随 着 IP 网 络 的 高 速 发 展 ， 当 初 设 计 的 IPv4 仍 面临 了 以 下 这 些 无 
法 解决 的 实际 问题 。 


(1) IPv4 地 址 空间 面临 枯竭 


我 们 知道 ，IPv4 地 址 分 私 网 地 址 和 公 网 地 址 两 大 类 ， 私 网 地 址 就 
是 仅 用 于 局 域 网 内 部 使 用 的 ， 不 同 企业 都 可 以 重复 使 用 ， 而 公 网 地 址 
则 是 全 球 唯一 的 ， 是 需要 注册 、 购 买 的 ， 一 个 地 址 只 能 在 一 个 地 方 使 
用 。 由 此 可 见 ， 公 网 JP 地 址 可 以 说 是 用 一 个 少 一 个 。 但 IPv4 地 址 仅 32 
位 ， 总 体 可 提供 的 地 址 数 有 限 ， 更 别 说 公 网 地 址 了 。 这 是 IPv4 最 终 走 
向 死亡 的 最 主要 的 因素 。 


IPv4 地 址 已 经 变 得 相当 缺乏 ， 时 至 今日 全 球 几 乎 都 无 耻 地 址 可 分 
了 ， 这 大 大 影响 了 计算 机 网 络 的 发 展 ， 也 严重 不 适应 当前 移动 互联 
网 、 物 联网 等 新 兴 互 联网 技术 的 发 展 和 普及 。 尽 管 我 们 一 直 在 采用 像 
NAT (Network Address Translation， 网 络 地 址 转换 ) 、VLSM 

(Variable Length Subnet Mask， 可 变 长 子 网 掩 码 ) 、CIDR (Classless 
Inter-Domain Routing， 无 类 域 间 路 由 ) 这 类 可 以 更 加 充分 使 用 现 有 公 


网 IP 地 址 的 技术 ， 但 仍然 很 难 满足 从 企业 到 个 人 的 新 兴 互 联网 应 用 需 
求 ， 于 是 采用 新 的 IPv6 协 议 的 呼声 在 全 球 范 围 内 日 益 高 涨 。 有 关 
NAT、VLSM 和 CIDR 等 技术 将 在 第 8 章 中 具体 介绍 。 


(2) 上 骨干 路 由 器 维护 的 路 由 表 表 项 数量 过 多 


由 于 IPv4 发 展 初期 的 分 配 规划 的 问题 ， 造 成 许多 IPv4 地 址 块 分 配 
不 连续 ， 不 能 有 效率 合 路 由 。 针 对 这 一 问题 ， 虽 然 通过 采用 CIDR， 以 
及 回收 并 再 分 配 公 网 IPv4 地 址 的 方法 有 效 抑制 了 全 球 IPv4 BGP 路 由 表 
的 线性 增长 。 但 目前 全 球 IPv4 BGP 路 由 表 仍 在 不 断 增长 ， 已 经 达到 17 
万 多 条 ， 经 过 CIDR 育 合 以 后 的 BGP 也 将 近 10 万 条 。 日 益 庞大 的 路 由 表 
耗 用 内 存 较 多 ， 对 设备 成 本 和 转发 效率 都 有 一 定 的 影响 ， 这 一 问题 促 
使 设备 制造 商 不 断 升级 其 路 由 器 产品 ， 提 高 其 路 由 寻 址 和 转发 的 性 


合 巴 
月 “ 


(3) 地 址 结构 不 合理 


IPv4 地 址 的 A、B、C、D 和 E 这 五 种 本 号 的 分 类 结构 就 存在 严重 缺 
陷 ， 不 利于 地 址 资源 的 充分 利用 。 如 果 一 个 组 织 分 配 了 A 类 地 址 ， 大 
部 分 的 地 址 空间 被 浪费 了 ; 如 果 一 个 组 织 分 配 了 C 类 地 址 ， 地 址 空间 
又 严重 不 足 ， 而 且 D 类 和 E 类 地 址 都 无 法 利用 。 虽 然 可 能 通过 YLSM 和 
CIDR 技 术 来 弥补 ， 但 这 同样 会 使 路 由 表 和 路 由 策略 变 得 十 分 复杂 ， 大 

影响 了 路 由 效率 。 


(4) 配置 复杂 


目前 大 多 数 IPv4 的 实现 方案 必须 手动 配置 ， 或 通过 控制 状态 的 地 
址 配置 协议 进行 配置 ， 例 如 通过 动态 主机 配置 协议 (DHCP) 进行 配 
置 。 随 着 使 用 IP 的 计算 机 和 设备 越 来 越 多 ， 越 来 越 需要 更 简单 更 目 动 
化 的 地 址 配置 和 其 他 不 依赖 于 DHCP 基 础 结构 的 管理 配置 设置 。IPv6 
协议 束 有 这 种 目 动 配置 功能 。 


(5) 服务 质量 差 


因为 IPv4 是 一 个 无 连接 协议 ， 所 以 它 本 身 就 具有 不 可 靠 性 。 虽 然 
IPv4 有 服务 质量 (QoS) 标准 ， 但 是 实时 通信 支持 依赖 于 IPv4 服 务 类 
型 (ToS) 字段 和 负载 的 标识 ， 通 常 使 用 UDP 或 TCP 端 口 。 不 焉 的 是 ， 
IPv4 协 议 的 ToS 字 段 功能 有 限 ， 并 且 有 不 同 的 解释 。 另 外 ， 当 IPv4 数 据 
报 负载 被 加 密 后 ， 负 载 标识 使 用 TCP 和 UDP 端口 是 不 可 能 的 。 


(6) 不 文 持 端 到 喘 安全 


因为 IPsec 只 是 IPv4 中 的 一 个 可 选项 ， 且 在 实际 部 署 中 多 数 节 点 都 
不 支持 IPSec， 所 以 IPv4 的 安全 性 比较 差 。 另 外 ，IPv4 中 的 NAT 需 要 对 
IP 报 文 头 进行 修改 ， 有 时 甚至 需要 修改 相关 应 用 数据 ， 而 在 端 到 问安 
全 中 ，IP 报 头 的 完整 性 通过 加 密 来 保证 ， 报 文 的 发 出 者 负责 保护 报 文 


头 的 完整 性 ， 在 接收 问 检 查收 到 报 文 的 完整 性 ， 在 转发 过 程 中 任何 对 


报头 的 修改 都 会 破坏 完整 性 检查 ， 所 以 在 部 嗜 NAT 的 情况 下 无 法 文 持 


端 到 问 的 安全 。 


7.3.3 IPv6 的 主要 优势 


为 了 解决 以 上 IPv4 的 这 些 不 足 ，Internet 工 程 任 务 组 (IETF) 又 开 
发 了 一 组 协议 和 标准 ， 那 束 是 IPv6 协 议 复 ， 其 中 最 主要 的 协议 当然 就 
是 IPv6 了 “。IPv6 与 IPv4 协 议 一 样 ， 也 是 一 种 无 连接 的 、 不 可 笔 的 数据 
报 协议 ， 主 要 用 于 在 主机 之 间 寻 址 和 路 由 数据 报 。 


新 的 IPv6 协 议 相 对 目前 正在 使 用 的 IPv4 协 议 来 说 主要 具有 以 下 几 
方面 的 新 特性 。 


(1) 更 大 的 地 址 空间 


IPv6 的 地 址 结构 中 有 128 位 〈16 字 节 ) ， 比 起 IPv4 的 32 位 (4 字 
节 ) 来 说 扩展 了 4 倍 ， 可 以 极 大 地 满足 未 来 新 兴 互联 网 技术 和 应 用 发 展 
的 地 址 需求 。 初 步 估算 ， 全 球 每 个 人 都 可 以 分 到 差不多 10 个 专用 IP 地 
址 ， 到 那 时 我 们 每 个 人 都 可 以 在 互联 网 上 有 唯一 的 身份 了 。 


(2) 有 效 和 分 级 的 寻 址 及 路 由 基础 结构 


IPv6 地 址 长 度 为 128 位 ， 可 提供 远大 于 IPv4 的 地 址 空间 和 网 络 前 
级 ， 因 此 可 以 方便 地 进行 网 络 的 层次 化 部 署 。 同 一 组 织 机 构 在 其 网 络 
中 可 以 只 使 用 一 个 前 级 。 对 于 ISP， 则 可 获得 更 大 的 地 址 空间 。 这 样 
ISP 可 以 把 所 有 客户 聚合 形成 一 个 前 绥 并 发 布 出 去 。 分 层 聚 合 使 全 局 路 


由 表 项 数量 很 少 ， 转 发 效率 更 高 。 必 外， 由 于 地 址 空间 巨大 ， 同 一 客 
户 使 用 多 个 ISP 接 入 时 可 以 同时 使 用 不 同 的 前 缀 ， 这 样 不 会 对 全 局 路 由 


表 的 聚合 造成 影响 。 
(3) 支持 无 状态 和 控制 状态 的 地 址 配置 


为 了 简化 主机 配置 ，IPv6 既 支持 控制 状态 的 地 址 配置 ， 例 如 
DHCP 服 务 絮 存在 时 的 地 址 配置 ， 也 支持 无 状态 的 地 址 配置 ， 即 DHCP 
服务 器 不 存在 时 的 地 址 配置 。 使 用 无 状态 的 地 址 配置 ， 链 接 上 的 主机 
将 使 用 用 于 该 链接 的 IPv6 地 址 (本 地 链接 地 址 ) 和 由 本 地 路 由 器 广告 
的 前 缀 导出 的 地 址 ， 上 自动 配置 它们 自己 。 即 使 没有 路 由 器 ， 同 一 个 链 
接 上 的 主机 也 可 以 自动 用 本 地 链接 地 址 配置 自己 ， 并 在 没有 手动 配置 
的 情况 下 通信 。 


(4) 对 服务 质量 (QoS) 的 更 好 支持 


IPv6 报 头 中 的 新 字段 定义 了 如 何 处 理 和 识别 通信 。 通 过 在 IPv6 报 
头 中 使 用 流标 签字 段 ， 通 信 标 识 人 多 许 路 由 器 识别 属于 流 的 数据 报 ， 并 
为 之 提供 特殊 处 理 。 因 为 在 IPv6 报 头 中 标识 通信 ， 所 以 即使 在 数据 报 
有 效 负 载 使 用 IPSec 加 密 时 也 很 容易 实现 对 QoS 的 文 持 。 


(5) 提供 用 于 邻近 结 点 交互 的 新 协议 


IPv6 的 ND (邻居 发 现 ) 协议 是 一 个 用 于 IPv6 的 Internet 控 制 消息 协 
议 ， 用 于 管理 邻居 结 点 ( 即 同一 链接 上 的 结 点 ) 的 交互 。ND 协 议 使 用 
有 效 的 多 播 和 单 播 消息 代 蔡 原来 IPv4 协 议 中 的 ARP 和 ICMPv4， 并 提供 
附加 的 功能 。 


(6) 可 扩展 性 


IPv4 中 虽然 也 文 持 IPSec， 但 只 是 通过 选项 文 持 ， 实 际 部 署 中 多 数 
结 点 都 不 支持 。 但 在 IPv6 中 ，IPSec 是 IPv6 协 议 基 本 定义 中 的 一 部 分 ， 
部 署 的 任何 结 点 都 必须 支持 。 因 此 ， 在 IPv6 中 支持 端 到 端 安全 要 容易 
导 多 。IPV6 中 支持 为 IP 定 义 的 安全 目标 : 保密 性 《只 有 预期 接收 者 能 
读数 据 ) 、 完 整 性 (数据 在 传输 过 程 中 没有 被 自 改 ) 、 验 证 性 (发 送 
数据 的 实体 和 所 宣称 的 实体 完全 一 致 ) 。 


一 个 


(7) 文 持 移动 特性 


IPv6 协 议 规 定 必须 文 持 移 动 特性 ， 任 何 IPv6 结 点 都 可 以 使 用 移动 
IP 功 能 。 与 移动 IPv4 相 比 ， 移 动 IPv6 使 用 邻居 发 现 功能 可 直接 实现 外 
地 网 络 的 发 现 并 得 到 转交 地 址 ， 而 不 必 使 用 外 地 代理 。 同 时 ， 利 用 路 
由 扩展 头 和 目的 地 址 扩展 头 可 实现 移动 结 点 和 对 等 结 点 之 间 的 直接 通 
信 ， 解 决 了 移动 IPv4 的 三 角 路 由 、 源 地 址 过 滤 问 题 ， 移 动 通信 处 理 效 
率 更 高 且 对 应 用 层 透 明 。 


7.3.4 _IPv4 数 据 报 头 部 格式 


发 送 端的 网 络 层 在 收 到 它 的 上 一 层 一 一 传输 层 发 来 的 数据 段 时 ， 
需要 通过 网 络 层 协议 将 其 封装 成 数据 报 ， 也 束 是 加 上 网 络 层 IP 协 议 
(在 此 仅 以 IP 网 络 为 例 进行 介绍 ) 头 部 。 耿 协议 头 部 主要 是 源 和 目的 网 
络 的 耳 地 址 ， 以 便 可 以 把 数据 分 段 传输 到 目的 网 络 中。 然后 数据 报 加 
下 传输 ， 到 了 数据 链 路 层 后 又 要 封 疹 成 数据 帆 。 


与 在 第 4 章 介绍 的 数据 帧 格式 中 包括 帧 头 和 数据 部 分 类 似 ， 一 个 IP 
数据 报 也 包括 报头 和 数据 这 两 个 组 成 部 分 ， 如 图 7-10 所 示 。 其 中 数据 部 
分 加 生来 目 传输 层 的 完整 数据 段 ， 而 报头 部 分 是 为 了 正确 传输 数据 报 
而 增加 的 网 络 层 IPv4 (此 处 仅 以 IPv4 网 络 为 例 进行 介绍 ) 协议 信息 。 


图 7-10 IPv4 数 据 报 基 本 结构 


1.IPv4 数 据 报头 部 格式 


IPv4 数 据 报 头 部 格式 如 图 7-11 所 示 ， 下 面 是 各 个 字段 的 说 明 。 


| 4 | 4| 8 1 3| 13 | 位 


污 部 长 度 区 于/ 本， 入 < 谨 
le 
ee pn 


源 地 址 


目的 地 址 


图 7-11 IPv4 数 据 报头 部 格式 


(1) 版 本 (Version) 


版 本 字段 指定 IP 数 据 报 中 使 用 的 IP 协 议 版 本 ， 占 4 位 。 此 处 是 IPv4 
版 本 ， 值 为 4 (0100) 。 


(2) 头 部 长 度 〈Header Length) 


头 部 长 度 字段 指示 卫 数 据 报 头 部 的 总 长 度 ， 了 数据 报头 部 的 总 长 度 
以 4 字 市 为 单位 ， 该 字段 占 4 位 。 当 报头 中 无 选项 字段 时 ， 报 头 的 总 长 
度 为 5， 即 20 字 节 (此 时 ， 报 头 长 度 值 为 0101) 。 这 就 是 说 IP 数 据 报头 
部 固定 部 分 的 长 度 为 20 字 节 。 当 IP 报 头 部 长 度 为 1111 时 ( 即 十 进 制 的 


定 部 分 长 度 就 达到 60 字 节 。 但 报头 长 度 必 须 是 32 位 (4 字 
， 如 果 不 是 ， 需 在 选项 字段 的 填充 (PAD) 子 字段 中 补 0 


和 


(3) 区 分 服务 (Differentiated Services ) 


最 开始 IP 数 据 报 的 这 个 字段 为 优先 级 和 服务 类 型 字段 ， 又 称 服务 
类 型 (ToS) 字段 ， 用 于 表示 数据 报 的 优先 级 和 服务 类 型 ， 占 8 位 。 它 
包括 一 个 3 位 长 度 的 优先 级 、4 位 长 度 的 标志 位 。 标 志 位 分 别 是 D 
(Delay， 延 迟 ) 、T (Throughput， 吞 叶 量 ) 、R (Reliability， 可 靠 
性 ) 和 C (Cost， 开 销 ) ， 分 别 表示 包 延 迟 、 吞 吐 量 、 可 靠 性 和 开销 
值 ， 用 来 获得 更 好 的 服务 。 最 高 1 位 未 用 。 


1998 年 IETF 在 RFC2474 中 把 IP 数 据 报 中 ToS 字 上 段 改名 为 区 分 服务 字 
段 ， 同 样 为 8 位 ， 前 6 位 构成 DSCP (Differentiated Services Code Point, 
区 分 服务 码 点 ) ， 是 IP 优 先 级 和 服务 类 型 字段 的 组 合 ， 定 义 了 0~63 共 
64 个 优先 级 。 最 后 2 位 未 使 用 。 无 论 是 哪 种 版 本 ， 该 字段 只 有 在 使 用 区 
分 服务 时 才 起 作用 ， 如 果 没 有 使 用 区 分 服务 ， 则 该 字段 值 为 0。 


(4) 总 长 度 (Total Length) 


总 长 度 字 段 标识 整个 了 数据 报 的 总 长 度 ， 包 括 报 头 和 数据 部 分 
整个 IP 数 据 报 总 长 度 以 字 节 为 单位 ， 该 字段 占 16 位 。 由 此 可 得 出 ，IPv4 


数据 报 的 最 大 长 度 为 216 -1 字 节 即 65535 字 节 ( 即 64KB) 。 之 所 以 要 减 
1， 是 因为 21 中 包括 0 这 个 值 。 


说 明 在 网 络 层 下 面 的 每 一 种 数据 链 路 层 都 有 目 己 的 帧 格式 ， 其 
中 包括 表示 数据 字段 的 最 大 长 度 ， 这 称 为 最 大 传送 单元 (Maximum 
Transfer Unit，MTU) 。 当 一 个 数据 报 封装 成 链 路 层 的 帧 时 ， 此 数据 报 
的 总 长 度 (包括 头 部 和 数据 两 部 分 ) 一 定 不 能 超过 下 面 的 数据 链 路 层 
的 MTU 值 。 具 体 将 在 下 市 介绍 IP 数 据 报 封 狼 时 介绍 。 


(5) 标识 (Identification) 


标识 字段 用 于 表示 IP 数 据 报 的 标识 符 ， 占 16 位 ， 每 个 IP 数 据 报 有 一 
个 唯一 的 标识 。IP 软 件 在 存储 器 中 维持 一 个 计数 器 ， 每 产生 一 个 数据 
报 ， 计 数 器 就 加 1， 并 将 此 值 赋 给 这 个 标识 字段 。 但 这 个 标识 并 不 是 序 
号 ， 因 为 IP 是 无 连接 服务 ， 数 据 报 不 存在 按 序 接收 的 问题 。 当 数据 报 
由 于 长 度 超过 下 面 数据 链 路 层 的 MTU 值 而 必须 分 段 时 ， 这 个 标识 字段 
的 值 就 被 复制 到 所 有 的 数据 报 分 段 的 标识 字段 中 。 相 同 的 标识 字段 的 
值 使 分 段 后 的 各 数据 报 分 段 最 后 能 正确 地 重 装 成 为 原来 的 数据 报 。 


(6) 标志 (Flags) 


标志 字段 指出 该 IP 数 据 报 后 面 是 否 还 有 分 段 ， 也 束 是 这 个 字段 是 
分 段 标志 ， 占 3 位 。 目 前 只 有 前 两 位 有 意义 : 最 低 1 位 记 为 MF (More 
Fragment) ， 如 果 MF=1， 即 表示 后 面 还 有 分 段 ， 如 果 MF=0 表 示 这 已 是 


某 个 数据 报 的 最 后 一 个 分 段 ， 中 间 1 位 记 为 DF (Don't Fragment) ， 当 
DF=1 时 表示 不 允许 分 段 ，DF=0 时 表示 允许 分 段 ; 最 高 1 位 没有 使 用 。 


(7) 段 偏 移 (Fragment Offset) 


段 偏 移 字 段 用 以 指出 该 分 段 在 数据 报 中 的 相对 位 置 ， 也 就 是 说 ， 
相对 于 用 户 数据 字段 的 起 点 ， 该 分 段 从 何 处 开始 ， 占 13 人 位。 在 有 分 
段 ， 段 偏 移 以 8 字 节 为 偏 移 单位 ， 即 每 个 分 段 的 长 度 一 定 是 8 字 节 (64 
位 ) 的 整数 倍 。 第 一 个 分 段 的 段 偏 移 值 就 是 00000000000000， 如 果 第 
一 个 分 段 一 共 是 64 字 三 ， 则 第 二 个 分 段 的 仿 移 值 为 0000000001001， 相 
当 于 十 进 制 数 的 9， 因 为 它 是 从 第 9 个 “8 字 节 ”数据 块 开 始 的 。 如 果 没 有 
分 段 ， 则 该 字段 值 为 0 。 


(8) 生存 时 间 (Time To Live，TTL) 


生存 时 间 字 段 用 来 标识 卫 数 据 报 在 网 络 中 传输 的 有 效 期 ， 以 秒 
计数 ， 占 8 位 。 最 初 的 设计 是 以 秒 作为 TIL 的 单位 ， 每 经 过 一 个 路 由 器 
时 ， 就 在 TIL 中 减 去 数据 报 在 路 由 器 消耗 掉 的 一 段 时 间 。 考 数据 报 在 路 
由 器 消耗 的 时 间 小 于 1s， 就 把 TIL 值 减 1。TTL 的 建议 值 是 32s， 最 长 为 
28 -1=255s。 现 在 通常 认为 这 个 TTL 是 指数 据 报 允许 经 过 的 路 由 器 数 ， 
每 经 过 一 个 路 由 器 ， 则 TTL 减 1， 当 TIL 值 为 0 时 ， 就 丢弃 这 个 数据 报 。 
设 定 生存 时 间 是 为 了 防止 数据 报 在 网 络 中 无 限制 地 循环 转发 。 


(9) 协议 (Protocol) 


协议 字段 用 来 标识 此 了 数据 报 在 传输 层 所 采用 的 协议 类 型 (如 
TCP、UDP 或 ICMP 等 ) ， 以 便 使 目的 主机 的 卫 层 知道 应 将 数据 部 分 上 
交 给 哪个 处 理 过 程 ， 占 8 位 。 如 TCP 的 协议 号 是 6， 等 于 二 进 制 的 
00000110，UDP 的 协议 号 是 17， 等 于 二 进 制 的 00010001 。 


(10) 校 验 和 (checksum) 


校 验 和 字段 用 来 检验 IP 数 据 报 的 报头 部 分 〈 不 包括 “数据 ”部 分 ) 在 
传输 到 接收 咽 后 是 否 发 生 了 变化 ， 占 16 位 。 这 是 因为 数据 报 每 经 过 一 
个 路 由 器 ， 路 由 器 都 要 重新 计算 一 下 报头 检验 和 (因为 一 些 了 字段， 如 
生存 时 间 、 标 志 、 段 偏 移 等 都 可 能 发 生变 化 ) ， 不 检验 数据 部 分 可 减 
少 计 算 的 工作 量 。 


经 验 之 谈 ”利用 校 验 和 字段 检验 报头 部 分 数据 正确 性 的 基本 原理 
是 : 先 在 发 送 剖 校 验 和 字段 中 填 上 一 个 特定 的 值 ， 然 后 在 接收 端 把 包 
括 校 验 和 字段 在 内 的 报头 部 分 进行 二 进 制 反 码 求 和 ， 再 取 反 ， 如 果 结 
果 为 0， 则 表示 报头 部 分 在 传输 过 程 中 没有 发 生变 化 ， 否 则 表示 在 传输 
过 程 中 出 现 了 差错 。 从 以 上 可 以 看 出 ， 这 里 最 关键 的 是 在 发 送 端 计算 
出 这 个 校 验 和 的 值 。 它 的 计算 步 又 如 下 : 


1) 把 IP 数 据 报 报头 中 的 校 验 和 字段 置 0。 


2) 把 头 部 看 成 由 以 16 位 〈2 字 节 ) 为 单位 的 数字 组 成 ， 对 每 16 位 
的 二 进 制 反 码 进 行 求 和 。 如 报头 长 度 不 是 16 位 的 整数 倍数 ， 则 用 0 填充 


到 16 位 的 整数 倍数 。 若 此 时 校 验 和 字段 值 为 0， 可 以 不 计 ， 因 为 0 的 反 
码 仍 为 0。 


3) 以 上 得 到 的 结果 就 是 我 们 要 求 的 校 验 和 字段 值 ， 系 统 自 动 将 其 
填 入 IP 数 据 报 报 头 的 校 验 和 字段 中 。 


在 接收 端 ， 同 样 按照 以 16 位 为 单位 ， 对 IP 数 据 报 报头 部 分 进行 二 
进 制 反 码 求 和 ， 再 取 反 ， 如 果 结 果 为 0， 表 示 报 头 部 分 在 传输 过 程 中 没 
有 发 生 改 变 ， 否 则 表示 发 生 了 差错 。 但 要 注意 ， 此 时 因为 校 验 和 字段 
已 不 再 是 0 了 ， 而 是 等 于 除了 校 验 和 字段 外 其 他 字段 的 反 码 之 和 。 现 在 
再 对 校 验 和 字段 值 取 反 求 和 ， 再 与 其 他 字段 的 反 码 之 和 (相当 于 原 
来 “ 校 验 和 ”字段 的 值 ) 相 加 ， 结 果 肯 定 是 全 为 1， 因 为 这 两 个 值 互 为 反 
码 ; 再 取 反 后 ， 结 果 肯 定 为 0 这 就 是 校 验 和 的 基本 原理 。 


举 个 简单 的 例子 ， 假 设 有 3 个 数 (为 了 简便 ， 在 此 均 用 4 位 表 

示 ) : 2 (0010) 、3 (0011) 、C (代表 校 验 和 字段 值 ，， 计 算 C， 即 
求 2 和 3 的 反 码 之 和 ， 得 到 9 (1001) 。 现 在 假设 把 这 3 个 数 (2，3 和 C) 
传送 到 接收 端 。 在 接收 端 也 要 对 这 3 个 数 进行 反 码 求 和 。 因 为 2 和 3 这 两 
个 的 反 码 之 和 我 们 在 计算 C 时 就 已 得 出 了 ， 就 是 9 (1001) ， 现 在 只 需 
对 C (“ 校 验 和 ”字段 值 ) 进行 求 反 ， 得 到 6 (0110) 。 把 1001 与 0110 相 
加 ， 得 到 15 (1111) 。 再 取 反 ， 就 得 到 了 0。 这 就 是 这 3 个 数 在 传输 过 
程 没 有 出 现 差错 的 情况 下 得 到 的 ， 这 就 是 校 验 和 的 校 验 原理 。 


(11) 源 地 址 /目的 地 址 (Source Address/Destination Address) 


源 地 址 /目的 地 址 这 两 个 字段 分 别 表示 该 IP 数 据 报 发 送 痢 和 接收 阁 
的 IP 地 址 ， 各 占 32 位 。 在 整个 数据 报 传送 过 程 中 ， 无 论 经 过 什么 路 
由 ,无论 如 何 分 段 ， 此 两 字段 一 直 你 持 不 变 。 


(12) 选项 (Options) 


选项 字段 文 持 各 种 选项 ， 近 供 扩 展 余 地 。 根 据 选 项 的 不 同 ， 该 字 
段 是 可 变 长 的 ， 从 1 字 世 到 40 字 闻 。 用 来 文 持 排 错 、 测 量 以 及 安全 等 措 
施 。 作 为 选项 ， 用 户 可 以 使 用 ， 也 可 以 不 使 用 它们 。 但 作为 IP 协 议 的 
组 成 部 分 ， 所 有 实现 IP 协 议 的 设备 都 必须 能 处 理 IP 选 项 。 在 使 用 选项 的 
过 程 中 ， 如 果 造 成 IP 数 据 报 的 报头 不 是 32 位 的 整数 倍 ， 这 时 需要 使 用 
后 面 的 填充 字段 竣 齐 。 如 果 恰 好 为 整数 倍 ， 则 不 需要 填充 字段 。 


2.IP 数 据 报 报头 示例 


图 7-12 所 示 的 是 在 科 来 分 析 仪 上 通过 抓 包 得 出 的 IP 数 据 报 各 字段 值 
的 示例 ， 从 中 也 可 以 全 面体 现 图 7-11 所 示 的 IP 数 据 报头 部 格式 。 下 面 介 
绍 从 中 发 现 的 各 字段 值 。 


图 


7-12 IP 数据 报头 部 格式 示例 


口 版 本 : 4， 表示 当 前 网 络 中 为 IJPv4。 


“概要 统计 ， | 端点 | 协议 “会话” 粕 蜂 包 六 日 志 a | 4D 
而 伍 对 3 数据 包 : 6,587 | 
编号 绝对 时 间 切 襄 大 小 概要 全 

3866 09:36:13.494066 192.168.0.208:commplex-... 192.168.0.92:1030 TCP 64 | 片 列 号 = 

386? 09:36:13.494211 192.168.0.208:complex-,.. 192.168.0.92:1027 TCP 64 | 序列 号 = 

3868 | 09:36:13.494254 | 192.158.0.208: commplex-... |192.158.0.92:1028 Tree | ”564| 床 =v 
4 L | a 
日 . 玉 IP - 因特网 协议 [14/20] | 

加 隔 本 : a [1L47L] OxF0 
加 头 部 长 度 : 5 t20 字 节 } [14/1] 0x0P 
日 : 旧 区 分 服务 字段 ; 0000 0000 [15/1] OxFF 
加 优先 板 : Oy sass (路 由 信息 ) [15/1] QOxE0 
电 续 起 : sa wns (正堂 ) [15#1] 0x10 
电 天 上 时 量 : Ss i sl oe 
全 可 特性 ; aQis l hp TISZL1 ‘R04 
入 传 辆 内 改名 上 略 CE 往 : RO ‘各 临 } [15x1] 0x02 
冰 0 【在 拥 守 1 [1571] 0x0l 
组 长 度 : a0 (340 Bytes) [15#2] 三 
他 标识: OxXALAB [1681I] [18/2] 
珀 . 引 分 航标 志 : DI 1 不 要 分 忻 ) [2071] 0xE0 
@ 保留 : De Wa [2071] 0x80 
入 分 段 : wis i 不 要 分 眉 ) [20#1] 0x40 
和合 更 多 分 眉 ; ds 【最 后 一 个 四) [20/1] 0x20 
仇 分 恨 协 移 量 : 0 [20#2] OxlFFF 
各 生存 时 间 ;: 128 [2271] 
央 上 层 肉 : 攻 : 6 (TEPY E232 
时 以 驻 和 : Ox36A8 [正确 ) [2412] 
“四 证 IP 地 丝 : 192.168.0.208 [2673] 
赎 目标 I? 地 上 丝 : 192.168.0.92 [30/4] 
加 无 IB 选 项 [3420] 现 
名 一 TT | 多 
0000 | 00 14 85 CA ?5 22 00 OP 88 47 E8 B4 08 00 45 00 00 z8 41 AB 40 00 80 06 36 a8 |.-.... siG B.A...6 
CO as 00 DO CO aa 00 SC hic SS. 


口头 部 长 度 : 5， 表 示 IP 报 头 长 度 为 4 字 节 x5=20 字 节 。 


口 区 分 服务 字段 : 00000000， 表 示 当 前 IP 数 据 报 中 没有 使 用 服务 类 


型 字段 。 


口 总 长 度 : 40， 表 示 该 数据 报 总 长 为 40 字 节 


口 标识 : 表示 该 数据 报 的 标识 为 0x41AB 〈 十 六 进 制 ) 。 


口 分 段 标志 : 010， 第 2 位 为 1， 表 示 该 数据 报 不 能 个 分 段 ， 最 低位 
为 0， 表 示 后 面 没有 分 段 。 


口 分 段 仿 移 量 : 0， 表 示 没 有 被 分 段 。 


口 生 存 时 间 : 128， 表 示 该 数据 报 最 多 可 以 经 过 128 个 路 由 。 


口上 层 协 议 : 6， 表 示 卫 数据 报 的 传输 层 协议 为 TCP 协 议 。 


口 校 验 和 : 该 数据 报 校 验 和 为 0x36A8 (正确 ) ， 表 示 该 数据 报 是 
完整 的 。0x36A8 这 个 值 是 根据 本 慷 前 面 介绍 的 校 验 和 子 段 计算 原理 得 
出 的 。 


口 源 IP 地 址 ，192.168.0.208， 表 示 发 送 该 数据 报 的 源 记 点 IP 地 址 为 
192.168.0.208 。 


口 目 标 卫 地 址 : 192.168.0.92， 表 示 该 数据 报 发 送 的 目的 节点 卫 地 
址 为 192.168.0.92。 


口 无 了 选项: 表示 该 数据 报 没有 选项 字段 。 


7.3.5_IPv6 数 据 报 头 部 格式 


RFC 2460 定 义 了 IPv6 数 据 报 格式 。 总 体 结构 上 ，IPv6 数 据 报 格式 
与 IPv4 数 据 报 格式 是 一 样 的 ， 也 是 由 了 报头 和 数据 (在 IPv6 中 称 为 有 效 
载荷 ) 这 两 部 分 组 成 ， 但 在 IPv6 数 据 报 数据 部 分 还 可 以 包括 0 个 或 多 个 
IPv6 扩 展 报头 (Extension headers) ， 如 图 7-13 所 示 。IP 报 头 部 分 固定 
为 40 字 节 长 度 ， 而 有 效 载 答 部 分 最 长 不 得 超过 65535 字 条 。 


< 40F > 小 于 等 于 65535 字 节 > 


IPv6 报 头 扩展 报头 
« IPv6 有 效 载 向 | 


图 。 7-13 ”IPv6 数 据 报 结构 


IPv6 和 IPv4 之 间 最 显著 的 区 别 为 : IP 地 址 的 长 度 从 32 位 增加 到 128 


位 。 


通过 裁减 IPv4 报 头 中 的 某 些 字段 ， 或 把 一 些 字段 移入 到 扩展 报头 
中 ，IPv6 基 本 报头 的 最 大 总 长 度 大 大 减 小 了 。IPv6 使 用 固定 长 度 的 基本 
报头 ， 从 而 简化 了 转发 设备 对 IPv6 报 文 的 处 理 ， 提 高 了 转发 效率 。 尽 
管 IPv6 地 址 长 度 是 IPv4 地 址 长 度 的 4 倍 ， 但 IPv6 基 本 报头 的 长 度 只 有 40 
字 节 ， 为 固定 的 IPv4 报 文 头 长度 (不 包括 选项 字段 ) 的 2 倍 。IPv6 报 头 


格式 如 图 7-14 所 示 。 下 面 是 各 字段 介绍 ， 关 键 是 要 理解 各 个 字段 的 作 


用 。 


跳 数 限制 


有 效 载荷 长 度 
源 IP 地 址 ( 128 位 ) 


目的 IP 地 址 ( 128 位 ) 


图 7-14 IPv6 报 头 格 式 


(1) 版 本 (Version) 
版 本 字段 用 来 表示 IP 数 据 报 使 用 的 是 IPv6 协 议 封 装 ， 占 4 位 ， 对 应 


值 为 6 (0110) 

(2) 通信 分 类 (Traffic Class) 
信 分 类 字段 用 来 标识 对 应 IPv6 数 据 报 的 通信 流 类 别 ， 或 者 说 是 
， 类 似 于 IPv4 数 据 报 中 的 Tos (服务 类 型 ) 字段 。 


We 


优先 级 别 ， 占 8 位 


(3) 流标 签 (Flow Label) 


流标 釜 字段 是 IPv6 数 据 报 中 新 增 的 一 个 字段 ， 占 20 位 ， 可 用 来 标 
记 报 文 的 数据 流 类 型 ， 以 便 在 网 络 层 区 分 不 同 的 报 文 。 流 标签 字段 由 
源 世 点 分 配 ， 通 过 流标 和 位 、 源 地 址 、 目 的 地 址 三 元 组 方式 殉 可 以 唯一 
标识 一 条 通信 流 ， 而 不 用 像 IPv4 那 样 需 要 使 用 五 元 组 方式 〈 源 地 址 、 
目的 地 址 、 源 端口 、 目 的 端口 和 传输 层 协议 号 ) 。 这 样 发 动 的 最 大 好 
处 有 两 点 : 一 是 流标 签 可 以 和 任意 的 流 关 联 ， 需 要 标识 不 同类 型 的 流 
(可 以 是 非 五 元 组 ) 时 ， 无 须 对 流标 签 做 改动 ， 二 是 流标 签 在 IPv6 基 
本 头 中 ， 使 用 IPSec 时 此 域 对 转发 路 由 器 可 见 ， 因 此 转发 路 由 右 可 以 在 
使 用 IPv6 报 文 IPSec 的 情况 下 仍然 可 以 通过 三 元 组 (流标 签 、 源 地 址 、 
目的 地 址 ) 针对 特定 的 流 进行 QoS (质量 服务 处理 。 


(4) 有 效 载 丛 长 度 (Payload Length) 


有 效 载荷 长 度 字段 是 以 字 节 为 单位 标识 IPv6 数 据 报 中 有 效 载荷 部 
分 (包括 所 有 扩展 报头 部 分 ) 的 总 长 度 ， 也 就 是 除 IPv6 基 本 报头 以 外 
其 他 部 分 的 总 长 度 ， 占 20 位 。 


(5) 下 一 个 头 部 (Next Header) 
下 一 个 头 部 字段 用 来 标识 当前 报头 〈 或 扩展 报头 ) 的 下 一 个 头 部 
的 类 型 ， 占 8 位 。 每 种 扩展 报头 都 有 其 对 应 的 值 ， 具 体 将 在 下 节 介 绍 。 


下 一 个 头 部 字段 内 定义 的 扩展 报头 类 型 与 IPv4 报 文中 的 协议 字段 值 类 
似 ， 但 在 IPv6 数 据 报 中 ， 紧 接着 IPv6 报 头 的 可 能 不 是 上 层 协 议 头 部 ( 当 


没有 扩展 报头 或 者 为 最 后 一 个 扩展 报头 时 后 面 才 是 上 层 协议 头 ) ， 而 
征 IPv6 扩 展 报 头 。 这 一 机 制 下 处 理 扩展 头 更 高 效 ， 因 为 标识 了 数据 报 
中 对 应 的 上 层 协 议 或 扩展 报头 类 型 ， 转 发 路 由 右 只 处 理 必须 处 理 的 选 
项 扩展 报头 ， 提 高 了 转发 效率 。 


(6) 跳 数 限制 (Hop Limit) 


跳 数 限制 字段 与 1Pv4 报 文中 的 TTL 字 段 类 似 ， 指 定 了 报 文 可 以 有 效 
加 发 的 次 数 ， 占 8 位 。 报 文 每 经 过 一 个 路 由 紫 结 点 ， 跳 数值 整 减 1， 当 
此 字段 值 减 到 0 时 ， 则 直接 丢弃 该 报 文 。 


经 验 之 谈 同一 路 由 右上 所 连接 的 多 个 网 段 之 间 的 跳 数 为 0， 也 下 
征 在 同一 路 由 疹 上 上 所 连接 的 多 个 网 络 是 直接 相通 的 ， 不 用 配置 路 由 。 
这 也 走 像 网 天 、 路 由 亏 这 类 设备 通过 它们 上 面 的 多 个 端口 融 可 以 连接 
多 个 不 同 网 段 的 原因 。 但 古 不 同 网 天 、 路 由 右上 连接 的 不 同 网 段 是 必 
须要 配置 路 由 的 。 


另外 ， 之 所 以 称 为 “网关 ”， 征 因为 在 这 类 设备 上 仅 文 持 直 接连 接 
的 多 个 网 段 (每 个 网 络 连 接 在 一 个 端口 上 ) 间 通 过 它 本 身 即 可 实现 的 
互通 ， 不 提供 到 达 非 直接 连接 网 络 (也 就是 在 其 它 三 层 设备 上 连接 的 
网 络 ) 的 路 由 功能 。 但 要 注意 的 是 ， 我 们 在 计算 机 等 设备 上 配置 的 网 
天 并 不 古 指 与 它 所 直接 连接 交换 机 病 口 的 JP 地址 ， 而 是 指 三 层 设 备 上 
连接 该 计算 机 所 在 网 段 的 那个 端口 的 耻 地 址 。 网 关 下 地 址 必须 是 位 于 三 


层 设备 (如 网 关 、 路 由 器 、 三 层 交 换 机 ) 端口 上 的 ， 而 且 必 须 位 于 网 
络 边缘 〈 也 就 是 该 设备 的 其 他 端口 必须 连接 的 是 不 同 的 网 段 ) 的 端口 
和 


(7) 源 IP 地 址 (Source IP Address) 


源 IP 地 址 字段 标识 了 发 送 该 IPv6 报 文 源 节 点 的 IPv6 地 址 ， 占 128 


(8) 目的 IP 地 址 (Destination IP Address) 


目的 IP 地 址 字段 标识 了 IPv6 报 文 的 接收 市 点 的 IPv6 地 址 ， 占 128 


对 比 图 7-11 中 的 IPv4 数 据 报 头 部 格式 可 以 看 出 ，IPv6 去 除了 IPv4 报 
头 中 的 头 部 长 度 、 标 识 、 标 志 、 段 俩 移 、 校 验 和 、 选 项 、 填 充 这 么 多 
字段 ， 却 只 增 了 流标 签 这 一 个 字段 ， 因 此 IPv6 报 头 处 理 和 IPv4 相 比 大 大 
简化 ， 提 高 了 处 理 效率 。 另 外 ，IPv6 为 了 更 好 地 支持 各 种 选项 处 理 ， 
提出 了 扩展 头 的 概念 ， 新 增 选项 时 不 必修 改 现 有 结构 就 能 做 到 ， 理 论 
上 可 以 无 限 扩 展 ， 体 现 了 优异 的 灵活 性 。 


7.3.6 ”IPV6 扩 展 报 头 


在 图 7-14 中 可 以 看 到 ，IPv6 报 文中 可 以 携带 可 选 的 IPv6 扩 展 报 
头 。IPv6 扩 展 报头 是 跟 在 IPv6 基 本 报头 后 面 的 可 选 报头 。 由 于 在 IPv4 
的 报头 中 包含 了 几乎 所 有 的 可 选项 ， 因 此 每 个 中 间 路 由 器 都 必须 检查 
这 些 选 项 是 否 人 存在。 在 IPv6 中 ， 相 关 选 项 被 统一 移 到 了 扩展 报头 中 ， 
这 样 中 间 路 由 器 不 必 人 处理 每 一 个 可 能 出 现 的 选项 ( 仅 有 “ 逐 跳 选项 ” 报 
头 是 必须 要 处 理 的 ) ， 提 高 了 路 由 器 处 理 数据 报 文 的 速度 ， 也 提高 
其 转发 性 能 。 


IPv6 扩 展 报 头 附加 在 IPv6 报 头目 的 下地 址 字段 后 面 ， 可 以 有 0 个 ， 
或 者 多 个 扩展 报头 。 主 要 的 IPv6 扩 展 报头 有 以 下 几 类 : 


(1) 逐 跳 选项 头 (Hop-by-Hop Options Header) 。 


本 扩展 报头 类 型 值 为 0 (在 IPv6 报 头 下 一 个 头 部 字段 中 定义 ， 下 
同 ) 。 此 扩展 报头 须 被 转发 路 径 所 有 结 点 处 理 。 目 前 在 路 由 告警 
(RSVP 和 MLDv1) 与 Jumbo 帧 处 理 中 使 用 了 逐 跳 选项 头 ， 因 为 路 由 告 
警 需要 通知 到 转发 路 径 中 所 有 结 点 ， 而 jumbo 帧 是 长 度 超 过 65535 字 市 
的 报 文 ， 传 输 这 种 报 文 需要 转发 路 径 中 所 有 结 点 都 能 正常 处 理 。 


(2) 目的 选项 头 (Destination Options Header) 。 


本 扩展 报头 类 型 值 为 60。 只 可 能 出 现在 两 个 位 置 : 路 由 头 前 ， 
这 时 此 选项 头 被 目的 节点 和 路 由 头 中 指定 的 结 点 处 理 ，@ 上 层 头 前 
(任何 ESP 头 后 ， 此 时 只 能 被 目的 节点 处 理 。 


移动 TPv6 中 使 用 了 目的 选项 头 ， 称 为 家 乡 地 址 选项 。 家 乡 地 址 选 
项 由 目的 选项 头 携 市 ， 用 于 移动 结 点 离开 “家 乡 ” 后 通知 接收 节点 此 移 
动 结 点 对 应 的 家 乡 地 址 。 接 收 季 点 收 到 市 有 家 乡 地 址 选项 的 报 文 后 ， 
会 把 家 乡 地 址 选项 中 源 地 址 《移动 世 点 的 家 乡 地 址 ) 和 报 文 中 源 地 址 
(移动 节点 的 转交 地 址 ) 交换 ， 这 样 上 层 协 议 始 终 认为 是 在 和 移动 市 
点 的 家 乡 地 址 通信 ， 实 现 了 移动 漫游 功能 。 


(3) 路 由 头 (Routing Header) 。 
本 扩展 报头 类 型 值 为 43， 用 于 源 路 由 选项 和 移动 IPV6 。 
(4) 分 段 涉 (Fragment Header) 。 


本 扩展 报头 类 型 值 为 44， 用 于 标识 数据 报 的 分 段 ， 在 IPv4 报 头 中 
就 有 对 应 的 字段 。 当 源 节 点 发 送 的 报 文 超过 传输 链 路 MTU 《〈 源 节点 和 
目的 节点 之 间 传 输 路 径 的 MTU) 时 ， 需 要 对 报 文 进行 分 段 时 使 用 。 


(5) 认证 头 (Authentication Header) 。 


本 扩展 报头 类 型 值 为 51， 用 于 IPSec， 提 供 报 文 验证 、 完 整 性 检 


得 。 


(6) 封闭 安全 有 效 载 集 涉 (Encapsulating Security Payload 


本 扩展 报头 类 型 值 为 50， 用 于 IPSec， 提 供 报 文 验证 、 完 整 性 检查 
和 加 密 。 


(7) 上 层 头 
这 是 用 来 标识 数据 报 中 上 层 协议 类 型 ， 如 TCP、UDP、ICMP 等 。 


注意 ”目的 选项 头 最 多 出 现 两 次 : 一 次 在 路 由 头 前 ， 一 次 在 上 层 
协议 头 前 ， 其 他 选项 头 最 多 出 现 一 次 。IPv6 下 点 必须 能 够 处 理 选 项 头 
( 逐 跳 选项 头 除外 ， 它 固定 只 能 紧 随 基 本 报头 之 后 ) 在 任意 位 置 出 
现 ， 以 保证 互通 性 。 


7.3.7_IPv4 数 据 报 的 封 竣 与 解 封闭 


因为 我 们 目前 使 用 的 主要 还 是 IPv4 协 议 ， 所 以 重点 还 是 介绍 与 IPv4 
相关 的 知识 。 本 万 要 介绍 IPv4 数 据 报 的 封装 和 解 封 装 。 为 了 简便 ，IPv4 
数据 报 仍 简称 IP 数 据 报 ， 除 非特 别 说 明 ， 本 童 后 面 的 所 有 IP 数 据 报 就 是 
指 IPv4 数 据 报 。 


发 送 端 网 络 层 生成 的 卫 数 据 报 还 要 继续 向 下 传输 ， 到 达 数 据 链 路 
层 后 就 要 封装 成 数据 帧 了 。 卫 数据 报 的 “ 帧 封装 原理 很 简单 ， 只 需 把 来 
目 网 络 层 的 整个 耻 数 据 报 (包括 包头 部 分 和 数据 部 分 当 作 数 据 链 路 
层 帧 的 数据 (data) 部 分 ， 然 后 在 前 面 加 上 与 数据 链 路 层 对 应 的 协议 头 
即 可 。 在 以 太 局 域 风 中， 由 于 数据 链 路 层 分 成 了 LLC 子 层 和 MAC 子 层 
这 两 层 ， 所 以 来 目 网 络 层 的 IP 数 据 报 在 到 达 数 据 链 路 层 后 先 要 经 过 LLC 
子 层 和 MAC 子 层 的 协议 头 封装 ， 最 终 形成 数据 链 路 层 的 以 太 网 MAC 
帧 ， 如 图 7-15 所 示 。 在 帧 头 中 我 们 一 般 要 加 上 了 源 和 目的 节点 的 MAC 
地 址 ， 因 为 数据 链 路 层 是 通过 MAC 地 址 进行 寻 址 的 ， 有 具体 参见 6.4.2 


十 上 


四 局 O 


| 


MAC 帧 | MAC 帧 头 


IP 数据 包 |P 数 据 包 包 六 数据 | 
! 上 ' 


图 7-15 以 太 网 中 的 IP 数 据 报 封装 流程 


以 上 所 述 是 经 过 一 个 网 络 的 情形 ， 如 采 一 个 IP 数 据 报 在 整个 传输 
过 程 中 要 经 过 几 个 网 络 时 ， 怎 么 办 呢 ? 这 时 其 实 又 涉及 一 个 解 封 狠 的 
过 程 。 解 封装 丈 是 由 数据 链 路 层 的 帧 格式 解 封 成 原始 的 数据 报 格式 。 


图 7-16 所 示 是 源 主机 发 送 一 个 JP 数据 报 经 过 两 个 路 由 名 连接 的 三 个 
网 络 时 的 封装 和 解 封 装 过 程 。 下 面 是 具体 的 流程 。 


大 主机 5 
2 网 络 1 ， IP 数据 包 作为 MAC 帧 的 数据 


C3 路 由 器 1 。 「 下 包头 
上 


”网 络 2 、 IP 数据 包 作为 MAC 帧 的 数据 


了 网络 3 ， 让 数据 包 作为 MAC 帧 的 数据 


局 om 
图 7-16 IP 数 据 报 经 过 多 个 网 络 时 的 封 妆 和 解 封 妆 流 程 


1) 当 源 主机 发 送 一 个 下 数据 报时 ， 在 内 网 网 络 1 中 传输 是 以 帧 形 
式 进 行 的 ， 所 以 首先 需要 把 原始 的 也 数据 报 封装 成 帧 ， 在 网 络 1 的 链 路 
上 进行 传输 。 此 时 把 原来 IP 数 据 报 作为 整个 MAC 帧 的 “数据 ”部 分 ， 然 
后 加 上 网 络 1 链 路 层 协议 的 头 部 信息 ， 作 为 帧 头 ， 即 帧 头 1。 


2) 当 帧 传输 到 路 由 器 1 连接 网 络 1 的 接口 时 ， 相 当 于 要 把 帧 从 数据 
链 路 层 上 传 到 网 络 层 ， 于 是 要 对 原来 的 帧 进行 解 封 流 ， 去 挥 帧 头 和 帧 
尾 信息 (在 有 帧 尾 的 情况 下 ) ,还原 出 原来 的 IP 数 据 报 ， 以 识别 包 中 
的 目的 地 址 信息 ， 然 后 根据 路 由 右 中 的 路 由 表 信息 进行 路 由 转发 。 此 
时 了 数据 报 的 内 容 都 没 变 ， 包 括 卫 包头 部 分 中 的 源 和 目的 地 址 信息 等 。 


3) 当 IP 数 据 报 在 路 由 器 1 中 从 网 络 1 路 由 到 网 络 2 后 ， 又 需要 在 网 
络 2 的 链 路 层 进行 传输 ， 所 以 又 要 重 狐 封装 成 帧 ， 仍 把 原来 的 整个 了 了 数 
据 报 作为 数据 部 分 ， 不 过 此 时 加 上 的 是 网 络 2 链 路 层 的 协议 头 信息 作为 
帧 头 部 ， 即 帧 头 2。 


4) 当 帧 传输 到 路 由 器 2 连接 网 络 2 的 接口 时 ， 又 相当 于 从 数据 链 路 
层 到 了 网 络 层 ， 所 以 又 要 对 烦 进 行 解 封 装 ， 仍 旧 还 原 出 原来 的 数据 
报 ， 使 路 由 万 2 可 以 识别 包 中 的 目的 地 址 信息 ， 只 有 这 样 路 由 融 2 才 可 
以 根据 其 路 由 表 信 息 进 行 正 确 的 数据 报 路 由 、 转 发 。 


5) 当 IP 数 据 报 在 路 由 器 2 中 从 网 络 2 路 由 到 网 络 3 后 ， 又 需要 在 网 
络 3 的 链 路 层 进 行 传输 ， 所 以 又 要 重新 封 北 成 央 ， 仍 把 原来 的 整个 IP 数 
据 报 作为 数据 部 分 ， 不 过 此 时 加 上 的 是 网 络 3 链 路 层 的 协议 头 信息 作为 
帧 头 部 ， 即 帧 头 3。 


6) 当 从 网 络 3 的 数据 链 路 层 把 帧 传输 到 目的 主机 时 ， 在 目的 主机 
上 上 又 会 对 帧 进行 解 封 流 ， 去 挥 帧 尖 和 巾 尾 ， 还 原 出 原来 的 IP 数 据 报 ， 


以 获取 IP 数 据 报 中 的 真正 数据 。 


从 以 上 过 程 可 以 看 出 ，IP 数 据 报 无 论 经 过 了 多 少 个 网 络 ， 整 个 数 
据 报 内 容 都 是 不 会 改变 的 ， 包 括 包 头 部 分 的 源 和 目的 地 址 信息 。 变 化 
的 只 是 在 不 同 网 络 数据 链 路 上 传输 的 帧 头 信息 ， 即 在 不 同 网 络 链 路 上 
传输 的 帧 源 MAC 地 址 会 改变 的 ， 目 的 MAC 地 址 不 会 改变 。 


7.3.8 IPv4 数 据 报 的 分 段 与 重组 


在 网 络 层 中 还 涉及 一 个 分 段 的 问题 ， 那 是 因为 不 同 网 络 线路 上 可 
以 传输 的 数据 报 大 小 是 有 限制 的 ， 且 可 能 是 不 同 的 ， 也 就 是 我 们 通常 
所 说 的 MTU (最 大 传输 单元 ) ， 所 以 如 有 果 一 个 网 络 中 收 到 的 数据 报 太 
大 ， 不 能 在 目的 网 络 中 一 次 传输 的 话 ， 就 要 对 原来 的 包 进 行 拆 分 ， 分 
成 一 个 个 小 的 数据 报 再 进行 传输 ， 这 如 是 本 世 将 要 介绍 的 耻 数 据 报 分 
段 。 在 发 送 问 进 行 了 分 段 ， 在 接收 闪 目 热 束 要 把 发 送 来 的 一 个 个 分 段 
重 狐 按 顺序 组 合 ， 恢 复 成 原始 的 大 数据 报 ， 这 就 是 本 万 要 介绍 的 另 一 
个 问题 一 一 PP 数据 报 重组 。 


当 一 个 IPv4 数 据 报 封装 成 数据 链 路 层 的 帧 时 ， 此 数据 报 的 总 长 度 
( 即 包头 加 上 数据 部 分 ) 一 定 不 能 超过 表 7-2 所 列 的 不 同 网 络 的 数据 链 
路 层 的 MTU 值 。 因 此 ， 一 个 IP 数 据 报 的 长 度 只 有 小 于 或 等 于 一 个 网 络 
的 MTU 时 才能 在 这 个 网 络 中 进行 传输 。 当 原来 的 IP 数 据 报 长 度 大 于 对 
应 网 络 链 路 的 MTU 时 怎么 办 呢 ? 这 时 束 得 对 这 个 大 的 IP 数 据 报 进行 拆 
分 ， 分 成 多 个 符合 对 应 网 络 链 路 MTU 要 求 的 小 的 数据 分 段 。 


表 7-2 不 同 网 络 数据 链 路 层 协议 的 MTU 值 


协议 
令 牌 环 (16Mbps) 
令 牌 环 (4Mbps) 
FDDI 


在 互联 网 中 ， 包 含 了 各 种 各 样 的 异 构 网 络 ， 一 个 路 由 器 也 可 能 连 
接着 具有 不 同 MTU 值 的 多 个 网 络 ， 从 一 个 网 络 上 接收 的 IP 数 据 报 并 不 
一 定 能 在 另 一 个 网 络 上 发 送 该 数据 报 。 如 图 7-17 所 示 ， 一 个 路 由 器 连接 
两 个 网 络 ， 其 中 一 个 网 络 为 以 太 网 ， 根 据 表 7-2 可 知 其 MTU 值 为 1500 字 
节 ， 另 一 个 为 X.25 网 络 ， 根 据 表 7-2 可 知 其 MTU 值 为 576 字 节 。 


| 以 太 网 (MTU=1500B) 之 二 X.25 网 (MTU=576B) -0 


E 机 A | 路 由 器 E 机 B 
图 7-17 路 由 器 连接 不 同 MTU 值 网 络 的 卫 数 据 报 传输 示例 


在 本 示例 中 ， 主 机 A 连接 着 MTU 值 为 1500 字 节 的 以 太 网 络 ， 这 样 
在 以 太 网 上 链 路 层 传输 的 帧 中 数据 部 分 ， 也 就 是 了 P 数 据 报 长 度 不 得 超 
过 1500 字 节 ， 而 主机 B 连 接着 MTU 值 为 576 字 节 的 X.25 网 络 ， 这 样 在 
X.25 网 络 链 路 传输 的 帧 中 的 数据 部 分 ， 也 就 是 IP 数 据 报 长 度 不 得 超过 
576 字 节 ， 即 两 个 网 络 中 链 路 上 传输 的 MTU 值 是 不 一 样 的 。 这 时 如 果 主 
机 A 要 把 一 个 1450 字 节 的 数据 报 发 送 给 主机 B， 路 由 器 可 以 接收 到 主机 
A 发 送 的 数据 报 ， 但 却 不 能 在 X.25 网 络 上 转发 它 ， 因 为 它 超 过 了 X.25 网 
络 链 路 上 MTU 的 限制 。 


为 了 解决 这 个 问题 ， 就 需要 在 路 由 器 上 对 接收 到 的 主机 A 发 来 的 IP 
数据 报 进行 分 段 ， 然 后 再 将 每 个 分 段 独 立地 进行 发 送 ， 可 以 像 正 常 的 
IP 数 据 报 一 样 经 过 独立 的 路 由 选择 等 处 理 过 程 ， 节 终 到 达 目 的 主机 。 


最 后 ， 还 需要 在 目的 主机 上 对 这 些 分 段 进行 重组 ， 恢 复原 始 的 大 IP 数 
据 报 。 


这 时 束 处 及 一 个 问题 ， 耳 数据 报 分 段 后 是 否 在 每 个 分 段 中 加 上 对 
应 的 人 P 包 头 信息 。 管 案 古 肯定 的 。 因 为 分 段 后 的 每 个 IP 包 分 段 都 需要 进 
行 单独 的 路 由 ， 所 以 必须 要 有 相应 的 IP 包 头 信息 。 这 时 就 得 把 原来 IP 数 
据 报 中 的 包头 部 分 复制 到 所 有 由 同一 个 IP 数 据 报 拆 分 的 分 段 上 。 田 
外 ， 还 需要 在 每 个 分 段 的 包头 部 分 对 标志 字段 和 段 侦 移 字段 值 进 行 对 
应 的 修改 。 


如 果 是 第 一 个 分 段 ， 则 标志 字段 的 第 一 位 (最 低位 ) 置 1 (表示 后 
面 还 有 分 段 ) ， 中 间 一 位 置 0 (表示 允许 分 段 ) ， 段 偏 移 字 段 值 为 
00000000000000; 如 果 是 中 间 分 段 ， 则 标志 字段 的 第 一 位 〈 最 低位 ) 
置 1， 中 间 一 位 置 0， 段 偏 移 字段 值 为 相应 的 偏 移 值 (以 8 个 字 市 为 单 
位 ) ; 如 果 是 最 后 一 个 分 段 ， 则 “标志 ”字段 的 第 一 位 〈 最 低位 ) 置 0， 
中 间 一 位 置 0 表示 此 分 段 是 最 后 一 个 分 段 ) ， 段 偏 移 字 段 值 也 为 相应 
的 偏 移 值 。 包 头 的 其 他 部 分 与 原始 IP 数 据 报 一 样 。 


在 路 由 右 或 主机 上 对 IP 数 据 报 进行 了 拆 分 后 ， 在 最 终 的 目的 主机 
上 要 将 接收 到 的 所 有 分 段 进行 重新 组 装 ， 这 就 是 IP 数 据 报 分 段 的 重组 
过 程 。IP 数 据 分 段 的 重组 是 根据 数据 报 的 标识 符 (由 同一 个 IP 数 据 报 拆 
分 的 各 分 段 标识 符 字段 是 相同 的 ) 、 段 偏 移 、 标 志 等 字段 进行 的 ， 按 
照 原来 拆 分 的 顺序 拼接 起 来 ， 但 拼接 时 只 保留 第 一 个 分 段 的 包头 信 


已， 分 段 的 包头 被 去 挥 ， 同 时 修改 第 一 个 分 段 包 头 信息 ， 不 设置 标志 
字段 和 段 偶 移 字 段 。 


7.3.9 ARP 协议 报 文 格式 及 ARP 表 


ARP (Address Resolution Protocol， 地 址 解析 协议 ) 是 将 IP 地 址 解 
析 为 以 太 网 MAC 地 址 (或 称 物 理 地 址 ) 的 协议 。 在 局 域 网 中 ， 当 主机 
或 其 他 网 络 设备 有 数据 要 发 送 给 另 一 个 主机 或 设备 时 ， 它 必须 知道 对 
方 的 网 络 层 地 址 《 即 耳 地址 ) 。 但 是 仅仅 有 耳 地 址 是 不 够 的 ， 因 为 卫 数 
据 报 文 必须 封装 成 帧 才能 通过 物理 网 络 发 送 ， 因 此 发 送 站 还 必须 有 接 
收 站 的 物理 地 址 ， 所 以 需要 一 个 从 了 地 址 到 物理 地 址 的 映射 。APR 就 是 
实现 这 个 功能 的 协议 。 


1.ARP 报 文 格式 


ARP 是 一 个 独立 的 三 层 协 议 ， 所 以 ARP 报 文 在 问 数 据 链 路 层 传 输 
时 不 需要 经 过 IP 协 议 的 封装 ， 而 是 直接 生成 自己 的 报 文 ， 其 中 包括 ARP 
报头 ， 到 数据 链 路 层 后 再 由 对 应 的 数据 链 路 层 协议 (如 以 太 网 协议 ) 
进行 封 活 。ARP 报 文 分 为 ARP 请 求 和 ARP 应 答 报 文 两 种 ， 它 们 的 报 文 格 
式 可 以 统一 为 如 图 7-18 所 示 。 下 面 是 各 字段 的 说 明 。 


MAC| IP py 
硬件 | 上 层 协 | 地 址 | 地 址 | 织 作 | 源 MAC 地 址 | 源 P 地 址 | 目的 MAC 地 址 | 目的 IP 地 址 
类 型 | 议 类 型 | 长 度 | 长 度 | 天 型 


< 一 ARP 报头 一 一 一 一 > 


峙 


图 7-18 ARP 报 文 格式 


口 醒 件 类 型 : 占 2 字 下 ， 表 示 ARP 报 文 可 以 在 哪 种 类 型 的 网 络 上 传 


葵 ， 值 为 1 时 表示 为 以 太 网 地 址 。 


口上 层 协 议 类 型 ， 占 2 了 字条， 表示 人 硬件 地 址 要 映射 的 协议 地 址 类 


， 有 映射 IP 地 址 时 的 值 为 0x0800。 


口 MAC 地 址 长 度 : 占 1 字 节 ， 标 识 MAC 地 址 长 度 ， 以 字 节 为 单 


， 此 处 为 6。 


DIP 协议 地 址 长 度 : 占 1 字 闻 ， 标 识 IP 地 址 长 度 ， 以 字 厄 为 单位 ， 


此 处 为 4。 


口 操作 类 型 : 占 2 字 节 ， 指 定 本 次 ARP 报 文 类 型 。1 表 示 ARP 请 求 报 


，2 表 示 ARP 应 答 报 文 。 


口 源 MAC 地 址 ， 占 6 子 方 ， 表 示 发 送 方 设备 的 硬件 地 址 。 


口 源 IP 地 址 ， 占 4 子 方 ， 表 示 发 送 方 设备 的 JP 地 址 。 


口 目的 MAC 地 址 ， 占 6 字 市 ， 表 示 接 收 方 设备 的 硬件 地 址 ， 在 请 求 


报 文 中 该 字段 值 全 为 0， 即 00-00-00-00-00-00， 表 示 任 意 地 址 ， 因 为 现 
在 不 知道 这 个 MAC 地 址 。 


口 目的 IP 地 址 ， 占 4 子 市 ， 表 示 接 收 方 设备 的 IP 地 址 。 


ARP 报 文 并 不 是 直接 在 网 络 层 上 发 送 的 ， 它 还 是 需要 向 下 传输 到 
数据 链 路 层 ， 所 以 当 ARP 报 文 传输 到 数据 链 路 后 ， 需 要 再 次 进行 封 

。 以 以 太 网 为 例 ，ARP 报 文 传输 到 以 太 网 数据 链 路 层 后 会 形成 ARP 
央 。ARP 帕 格式 如 图 7-19 所 示 ， 它 束 是 在 ARP 报 文 前 面 加 了 一 个 以 太 网 
帆 头 。 


6 6 2 2 05 1 江 了 6 4 6 4 字 节 
、 ag MAG TID, ge. | ‘ses, 
目的 MAC | 源 MAC joayl 硬件 | 上 层 协 | ,操作 | 源 MAC | 源 IP 地 址 旧 的 MAC 地 圳 目的 IP 地 十 
地 址 ”| 地址 ” 虱 类 型 类 型 议 类 型 旧址 地址 类 型 | 地 址 | 


长 度 长 度 


< 一 一 以 太 网 帧 站 一 一 上 一 一 ARP 报 头 — 


图 7-19 ARP 帧 格式 
以 太 网 帧 头 中 的 三 个 字段 说 明 如 下 : 


口 目 的 MAC 地 址 : 占 6 字 节 ， 如 果 是 ARP 请 求 帧 ， 因 为 它 是 一 个 广 
播 帧 ， 所 以 要 填 上 广播 MAC 地 址 一 FF-FF-FF-FF， 其 目标 是 网 络 上 的 
所 有 主机 。 


口 源 MAC 地 址 : 占 6 字 节 ， 这 是 发 送 ARP 帧 的 万 点 MAC 地 址 。 


口 幅 类 型 ， 占 2 字 节 ， 这 里 用 来 标识 帧 封装 的 上 层 协议 ， 因 为 本 帧 
的 数据 部 分 是 ARP 报 文 ， 所 以 直接 用 ARP 的 协议 号 0x0806 表 示 即 可 。 


2.ARP 了 映射 表 


无 论 是 主机 ， 还 是 交换 机 都 会 有 一 个 用 来 缓存 同一 网 段 设 备 卫 地 
址 和 MAC 地 址 的 ARP 映 射 表 ， 用 于 数据 帧 的 转发 。 设 备 通过 ARP 解 析 
到 目的 MAC 地 址 后 ， 将 会 在 自己 的 ARP 映 射 表 中 增加 IP 地 址 到 MAC 地 
址 的 映射 表 项 ， 以 用 于 后 续 到 同一 目的 地 数据 帧 的 转发 。 


ARP 表 项 分 为 动态 ARP 表 项 和 静态 ARP 表 项 。 


(1) 动态 ARP 表 项 


动态 ARP 表 项 由 ARP 协 议 通 过 ARP 报 文 自 动 生成 和 维护 ， 可 以 被 老 
化 ， 可 以 被 新 的 ARP 报 文 更 新 ， 也 可 以 被 静态 ARP 表 项 所 获 盖 。 当 到 
达 老 化 时 间或 接口 关闭 时 会 删除 相应 的 动态 ARP 表 项 。 


(2) 静态 ARP 表 项 


静态 ARP 表 项 通过 手工 配置 (通过 对 应 设备 的 IP 地 址 与 MAC 地 址 
绑 定 命令 进行 ) 和 维护 ， 不 会 被 老化 ， 也 不 会 被 动态 ARP 表 项 覆盖 。 
配置 静态 ARP 表 项 可 以 增加 通信 的 安全 性 ， 因 为 静态 ARP 表 项 可 以 限 
制 和 指定 IP 地 址 的 设备 通信 时 只 使 用 指定 的 MAC 地 址 (也 就 是 我 们 通 
常 所 说 的 下地 址 与 MAC 地 址 的 绑 定 ) ， 此 时 攻击 报 文 无 法 修改 此 表 项 
的 IP 地 址 和 MAC 地 址 的 映射 关系 ， 从 而 保护 了 本 设备 和 指定 设备 间 的 
正常 通信 。 


静态 ARP 表 项 又 分 为 短 静 态 ARP 表 项 和 长 静态 ARP 表 项 。 


口 长 静态 ARP 表 项 。 在 配置 长 静态 ARP 表 项 时 ， 除 了 配置 耳 地 址 和 
MAC 地 址 项 外 ， 还 必须 配置 该 ARP 表 项 所 对 应 的 VLAN (虚拟 局 域 
网 ) 和 出 接口 。 也 就 是 长 静态 ARP 表 项 同时 绑 定 了 IP 地 址 、MAC 地 
址 、VLAN 和 端口 ， 可 以 直接 用 于 报 文 转发 。 


口 短 静 态 ARP 表 项 。 在 配置 短 静 态 ARP 表 项 时 ， 只 需要 配置 IP 地 址 
和 MAC 地 址 项 。 如 果 出 接口 是 三 层 以 太 网 接口 ， 短 静态 ARP 表 项 可 以 
直接 用 于 报 文 转发 ， 如 果 出 接口 是 VLAN 虚 接口 ， 短 静态 ARP 表 项 不 能 
直接 用 于 报 文 转发 ， 当 要 发 送 IP 数 据 包 时 ， 先 发 送 ARP 请 求 报 文 ， 如 果 
收 到 的 响应 报 文中 的 源 IP 地 址 和 源 MAC 地 址 与 所 配置 的 IP 地 址 和 MAC 
地 址 相同 ， 则 将 接收 ARP 响 应 报 文 的 接口 加 入 该 静态 ARP 表 项 中 ， 之 
后 就 可 以 用 于 JP 数据 包 的 转发 了 。 


7.3.10 ”ARP 地 址 解析 原理 


在 图 7-20 的 示例 中 ， 现 假设 主机 A 和 B 在 同一 个 网 段 ( 均 位 于 


192.168.1.0/24 网 段 ) ， 主 机 A 要 向 主机 B 发 送信 息 。 主 机 A 和 主机 B 的 IP 
地 址 和 MAC 地 址 均 在 图 中 己 有 标识 ， 此 时 主机 A 已 知道 主机 B 的 IP 地 
址 ， 要 想 获 得 主机 B 的 MAC 地 址 ， 具 体 的 地 址 解析 过 程 如 下 。 


Host A Host B 
192.168.1.1 192.168.1.2 
0002-6779-0f4c 00a0-2470-febd 
Sender MAC Sender IP Target MAC Target IP 
address address address address 
0002-6779-044c| 192.168.1.1 |0000-0000-0000| 192.168.1.2 


Sender MAC Sender IP Target MAC Target IP 
address address address address 
00a0-2470-tebd| 192.168.1.2 |0002-6779-044c| 192.168.1.1 


图 7-20 ARP 地 址 解析 示例 


1) 主机 A 首先 查看 自己 的 ARP 表 ( 它 是 一 个 IP 地 址 与 MAC 地 址 的 
映射 表 ) ， 确 定 其 中 是 否 包含 有 主机 B 的 IP 地 址 和 对 应 的 MAC 地 址 。 如 


果 找 到 了 对 应 的 MAC 地 址 ， 则 主机 A 直接 利用 ARP 表 中 的 MAC 地 址 对 
IP 数 据 包 进行 帧 封装， 并 将 数据 包 发 送 给 主机 B。 


2) 如 果 主 机 A 在 ARP 表 中 找 不 到 对 应 的 MAC 地 址 ， 则 先 缓存 该 数 
据 报 文 ， 然 后 以 广播 方式 (目的 MAC 地 址 为 广播 MAC 地 址 一 一 


FFFFFF， 任 一 同 网 段 的 节点 均 可 收 到 ) 发 送 一 个 ARP 请 求 报 文 。ARP 
请 求 报 文 中 的 发 送 端 〈 源 ) IP 地 址 和 发 送 端 MAC 地 址 分 别 为 主机 A 的 IP 
地 址 (192.168.1.1) 和 MAC 地 址 (0002-6779-0f4c) ， 目 的 IP 地 址 和 目 
的 MAC 地 址 为 主机 B 的 IP 地 址 (192.168.1.2) 和 全 0 的 MAC 地 址 。 因 为 
ARP 请 求 报 文 是 以 广播 发 方式 发 送 ， 所 以 该 网 段 上 的 所 有 主机 都 可 以 

接收 到 该 请 求 包 ， 但 只 有 其 下地 址 与 目的 卫 地 址 一 致 的 主机 B 会 对 该 请 
求 进 行 处 理 。 


3) 主机 B 将 ARP 请 求 报 文中 的 发 送 端 〈 即 主机 A) 的 IP 地 址 和 
MAC 地 址 存 入 自己 的 ARP 表 中 。 然 后 以 单 播 方式 向 主机 A 发 送 一 个 
ARP 啊 应 报 文 ， 应 答 报 文 中 惑 包含 了 目 己 的 MAC 地 址 ， 也 就 是 原来 在 
请 求 报 文 中 要 请 求 的 目的 MAC 地 址 。 


4) 主机 A 在 收 到 来 自主 机 B 的 ARP 响 应 报 文 后 ， 将 主机 B 的 MAC 地 
址 加 入 到 自己 的 ARP 表 中 以 用 于 后 续 报 文 的 转发 ， 同 时 将 原来 缓存 的 IP 
数据 包 再 次 修改 (在 “目的 MAC 地 址 ”字段 填 上 主机 B 的 MAC 地 址 ) 后 


这 就 是 同一 网 段 中 两 主机 的 ARP 地 址 解析 的 全 过 程 。 如 果 两 主机 
不 在 同一 ， 它 们 之 间 义 是 如 何 通 信 的 呢 ? 具体 步 又 如 下 : 


1) 如 果 主 机 A 不 知道 网 关 的 MAC 地 址 (也 就 是 在 主机 A 的 ARP 表 
中 没有 网 关 对 应 的 MAC 地 址 表 项 ) ， 则 主机 A 先 在 本 网 段 中 发 出 一 个 


ARP 请 求 广播 ，ARP 请 求 报 文中 的 目的 IP 地 址 为 网 天 IP 地 址 ， 代 表 其 日 
的 就 是 想 获 得 网 关 的 MAC 地 址 。 如 果 主 机 A 已 知 网 关 的 MAC 地 址 ， 则 
略 过 此 步 。 


2) 网 关 收 到 ARP 广 播 包 后 同样 会 向 主机 A 发 回 一 个 ARP 应 答 包 。 
当主 机 A 从 收 到 的 应 答 报 文中 获得 网 关 的 MAC 地 址 后 ， 在 主机 A 向 主机 
B 发 送 的 原 报 文 的 目的 MAC 地 址 字段 填 上 网 关 的 MAC 地 址 后 发 给 网 
天 o 


3) 如 果 网 关 的 ARP 表 中 已 有 主机 B 对 应 的 MAC 地 址 ， 则 网 关 直 接 
将 在 来 自主 机 A 的 报 文 中 的 目的 MAC 地 址 字段 填 上 主机 B 的 MAC 地 址 
后 转发 给 主机 B 。 


4) 如 果 网 关 ARP 表 中 没有 主机 B 的 MAC 地 址 ， 网 关 会 再 次 向 主机 
B 所 在 网 段 发 送 ARP 广 播 请 求 ， 此 时 目的 IP 地 址 为 主机 B 的 IP 地 址 ， 当 
网 天 从 收 到 来 目 主 机 B 的 应 答 报 文中 获得 主机 B 的 MAC 地 址 后 ， 束 可 以 
将 由 主机 A 发 来 的 报 文 重新 在 目的 MAC 地 址 字段 填 上 主机 B 的 MAC 地 
址 后 发 给 主机 B 。 


7.3.11 ICMP 协 议 及 报 文 格式 


ICMP 是 (Internet Control Message Protocol) Internet 控 制 报 文 协 
议 。 它 是 IPv4 协 议 簇 中 的 一 个 子 协议 ， 用 于 在 IP 主 机 、 路 由 器 之 间 传 递 
控制 消息 。 控 制 消息 是 指 网 络 通 不 通 、 主 机 是 否 可 达 、 路 由 是 否 可 用 
等 网 络 本 身 的 消息 。 这 些 欣 制 销 妃 虽然 并 不 传输 用 户 数据 ， 但 是 对 于 
用 户 数据 的 传递 起 着 重要 的 作用 。 


但 与 ARP 协 议 不 同 ，ICMP 依 靠 耳 协议 来 完成 其 任务 ， 所 以 ICMP 报 
文中 要 封装 IP 头 部 。 它 与 传输 层 协 议 (如 TCP 和 UDP) 的 目的 不 同 ， 一 
般 并 不 用 来 在 端 系统 之 间 来 传送 数据 ， 不 被 用 户 网 络 程序 直接 使 用 ， 
除了 像 Ping 和 tracert 文 样 的 诊断 程序 。 


1.ICMP 消 息 类 型 


ICMP 报 告 无 法 传送 的 数据 报 的 错误 ， 并 帮助 对 这 些 错误 进行 疑难 
解答 。 例 如 ， 如 采 IPv4 不 能 将 数据 报 传送 到 目标 主机 ， 则 路 由 郁 上 的 
或 目标 主机 上 的 ICMP 会 癌 主 机 发 送 一 条 “无 法 到 达 目 标清 轧 。 表 7-3 所 
示 为 最 解 见 的 ICMP 消 息 ， 并 作 了 说 明 。 


表 7-3 最 常见 的 ICMP 消息 


ICMP 消息 类 型 用 途 说 明 

回 显 请 求 Ping 工具 通过 发 送 ICMP 回 显 消息 检查 特定 节点 的 IPv4 连接 以 排查 网 络 问题 。 类 型 值 为 0 
回 显 应 答 节点 发 送 回 显 答复 消息 响应 ICMP 回 显 消息 。 类 型 值 为 8 

重 定向 路 由 器 发 送 “ 重 定向 ”消息 ， 告 诉 发 送 主机 到 目标 IPv4 地 址 更 好 的 路 由 。 类 型 值 为 5 

源 抑 制 路 由 器 发 送 “ 源 结束 ”消息 ， 告 诉 发 送 主机 它们 的 IPv4 数据 报 将 被 丢弃 一 一 因为 路 由 器 上 
发 生 了 拥塞 。 于 是 ， 发 送 主机 将 以 较 低 的 频 度 发 送 数 据 报 。 类 型 值 为 4 

超时 这 个 消息 有 两 种 用 途 。 第 一 ， 当 超过 IP 生存 期 时 向 发 送 系 统 发 出 错误 信息 。 第 二 ， 如 果 分 


段 的 IP 数据 报 没 有 在 某 种 时 限 内 重新 组 合 ， 这 个 消息 将 通知 发 送 系 统 。 类 型 值 为 11 
3 ai i 路 由 器 和 目标 主机 发 送 “ 无 法 到 达 目 标 ” 消 息 ， 通 知 发 送 主机 它们 的 数据 报 无 法 传送 。 类 型 
无 法 到 达 目 标 值 为 3 


在 表 7-3 中 的 “无 法 到 达 目 标 ” 消 息 中 还 可 细 分 ， 具 体 如 表 7-4 所 示 。 


表 7-4 ICMP 中 常见 的 “无 法 到 达 目 标 ” 消 息 


无 法 到 达 目 标 消息 说 明 
不 能 访问 主机 路 由 器 找 不 到 到 目标 IPv4 地 址 的 路 由 时 发 送 “ 不 能 访问 主机 ”消息 


目标 IPv4 节点 无 法 将 IPv4 标 头 中 的 “协议 ”字段 与 当前 使 用 的 IPv4 客户 端 协 议 相 
匹配 时 会 发 送 “ 无 法 访问 协议 ”消息 

IPv4 节点 在 无 法 将 UDP 标 头 中 的 “目标 端口 ”字段 与 使 用 该 UDP 端口 的 应 用 程序 
相 匹 配 时 发 送 “ 无 法 访问 端口 ”消息 

当 必须 分 段 但 发 送 节 点 在 IPv4 标 头 中 设置 了 “不 分 段 ”(DF) 标志 时 ，IPv4 路 由 器 
会 发 送 “ 需 要 分 段 但 设置 了 DF” 消 息 


无 法 访问 协议 
无 法 访问 端口 


需要 分 段 但 设置 了 DF 


ICMP 协 议 只 是 试图 报告 错误 ， 并 对 特定 的 情况 提供 反馈 ,但 最 终 
并 没有 使 IPv4 成 为 一 个 可 靠 的 协议 。ICMP 消 息 是 以 未 确认 的 IPv4 数 据 


报 传送 的 ， 它 们 目 己 也 不 可 靠 。 


2.ICMP 报 头 格 式 


ICMP 报 文 包含 在 IP 数 据 报 中 ，IP 报 头 在 ICMP 报 文 的 最 前 面 。 一 个 
ICMP 报 文 包 括 IP 报 头 (至 少 20 字 节 ) 、ICMP 报 头 (至 少 8 字 节 ) 和 
ICMP 报 文 (属于 ICMP 报 文 的 数据 部 分 。 当 IP 报 头 中 的 协议 字段 值 为 


1 时 ， 就 说 明 这 是 一 个 ICMP 报 文 。ICMP 报 头 格式 如 图 7-21 所 示 。 各 字 
段 的 说 明 如 下 。 


[Pv4 报 头 〈20 字 节 ) 


类 型 (1 字 节 ) | 代码 (1 字 节 ) 校 验 和 (2 字 节 ) 


ICMP 报 标识 (2 字 节 ) 
头 部 分 
选项 《可 有 可 无 ， 长 度 可 变 ) 


图 7-21 ICMP 报 头 格式 


口 类 型 : 占 1 字 下 ， 标 识 ICMP 报 文 的 类 型 ， 目 前 已 定义 了 14 种 ， 从 
类 型 值 来 看 ICMP 报 文 可 分 为 二 大 类 。 第 1 类 是 取 值 为 1~127 的 差错 报 
文 ， 第 2 类 是 取 值 128 以 上 的 是 信息 报 文 。 


口 代码 ， 占 1 字 节 ， 标 识 对 应 ICMP 报 文 的 代码 。 它 与 类 型 字段 一 起 
共同 标识 了 ICMP 报 文 的 详细 类 型 。 


口 校 验 和 : 这 是 对 包括 ICMP 报 文 数 据 部 分 在 内 的 整个 ICMP 数 据 报 
的 校 验 和 ， 以 检验 报 文 在 传输 过 程 中 是 否 出 现 了 差错。 其 计算 方法 与 
我 们 在 7.3.4 广 介绍 的 IP 报 关中 的 校 验 和 计算 方法 钙 一 样 的 。 


口 标识 : 占 2 字 节 ， 用 于 标识 本 ICMP 进 程 ， 但 仅 适 用 于 回 显 请 求 和 
应 答 ICMP 报 文 ， 对 于 目标 不 可 达 ICMP 报 文 和 超时 ICMP 报 文 等 ， 该 字 
友 导 全 为 0 


3. 常 见 的 ICMP 报 文 
下 面 是 几 种 常见 的 ICMP 报 文 。 
(1) 响应 请 求 


我 们 日 常 进 行 的 Ping 操 作 中 就 包括 响应 请 求 〈 类 型 字段 值 为 8) 和 
应 答 (类 型 字段 值 为 0 ICMP 报 文 。 一 台 主 机 向 一 个 节点 发 送 一 个 类 
型 字段 值 为 8 的 ICMP 报 文 ， 如 果 途 中 没有 异常 《如 没有 被 路 由 器 丢 
弃 、 目 标 不 回应 ICMP 或 传输 失败 ) ， 则 目标 返回 类 型 字段 值 为 0 的 
ICMP 报 文 ， 说 明 这 台 主 机 存在 。 


(2) 目标 不 可 到 达 、 源 抑制 和 超时 报 文 


这 三 种 报 文 的 格式 是 一 样 的 。 目 标 不 可 到 达 报 文 《类 型 字段 值 为 
3) 在 路 由 器 或 主机 不 能 传递 数据 报时 使 用 。 例 如 我 们 要 连接 对 方 一 个 
不 存在 的 系统 端口 (端口 号 小 于 1024) 时 ， 将 返回 类 型 字段 值 为 3、 代 
码 字段 值 为 3 的 ICMP 报 文 。 利 见 的 不 可 到 达 类 型 还 有 网 络 不 可 到 达 
(代码 字段 值 为 0) 、 主 机 不 可 到 达 〈 代 码 字段 值 为 1) 、 协 议 不 可 到 
达 (代码 字段 值 为 2) 等 。 


源 抑 制 报 文 《类 型 字段 值 为 4， 代 码 字段 值 为 0) 则 充当 一 个 控制 
流量 的 角色 ， 通 知 主机 减少 数据 报 流 量 。 由 于 ICMP 没 有 恢复 传输 的 报 
文 ， 所 以 只 要 停止 该 报 文 ， 主机 束 会 逐渐 恢复 传输 速率 。 最 后 ， 无 连 


接 方 式 网 络 的 问题 吏 是 数据 报 会 丢失 ， 或 者 长 时 间 在 网 络 游 沪 而 找 不 
到 目标 ， 或 者 拥塞 导致 主机 在 规定 时 间 内 无 法 重组 数据 报 分 段 ， 这 时 
就 要 触发 ICMP 超 时 报 文 的 产生 。 


超时 报 文 (类 型 字段 值 为 11) 的 代码 域 有 两 种 取 值 : 代码 字段 值 
为 0 表示 传输 超时 ， 代 码 字段 值 为 1 表示 重组 分 段 超时 。 


(3) 时 间 惟 请求 


时 间 惟 请 求 报 文 《类 型 值 字段 13) 和 时 间 惟 应答 报 文 (类 型 值 字 
段 14) 用 于 测试 两 台 主 机 之 间 数 据 报 来 回 一 次 的 传输 时 间 。 传 输 时 ， 
主机 填充 原始 时 间 惟 ， 接 收 方 收 到 请 求 后 填充 接收 时 间 惟 后 以 类 型 什 
字段 14 的 报 文 格式 返回 ， 发 送 方 计算 这 个 时 间 差 。 有 些 系统 不 啊 应 这 
种 报 文 。 


7.3.12 ”IPv6 协 议 复 中 的 其 他 协议 


除了 前 面 介 绍 的 IPv6 协 议 外 ， 在 IPv6 协 议 复 中 还 包括 ICMPv6、ND 
(邻居 发 现 ) 和 MLD (绝色 播 侦 听 器 发 现 ) 协议 。 这 些 协议 分 别 用 来 

取代 IPv4 协 议 得 中 的 对 应 协议 : 

DICMPv6 取 代 ICMP“。ICMPv6 提 供 诊 断 功能 ， 并 可 在 IPv6 数 据 报 
无 法 传送 时 报告 错误 。 

DMLD 取 代 IGMP。MLD 管 理 IPv6 多 播 组 成 员 身 份 。 

DND 取 代 ARPND 管 理 相 邻 节 点 间 的 交互 ， 包 括 目 动 配置 地 址 和 将 
下 一 跃 点 IPV6 地 址 解析 为 MAC 地 址 。 

因为 IPv6 毕 竟 目 前 还 没有 正式 全 面 使 用 ， 所 以 下 面 仅 对 这 些 协议 
进行 简单 介绍 。 

1.ICMPv6 

ICMPv6 与 前 面 介 绍 的 了 Pv4 协 议 复 中 的 ICMP 一 样 ， 用 于 报告 传送 或 


转发 中 的 错误 并 为 疑难 解答 提供 简单 的 回 显 服务 。 同 时 ICMPv6 协 议 还 
为 ND 和 MLD 消 息 提供 消息 结构 。 


表 7-5 所 示 为 RFC 2463 中 定义 的 ICMPv6 消 息 ， 并 作 了 说 明 。 


表 7-5 常见 的 ICMPv6 消息 


ICMPv6 消息 说 明 

回 显 请 求 发 送 主机 发 送 请 求 回 显 消息 来 检查 与 特定 节点 的 IPv6 连接 

回 显 应 答 节点 发 送 回 显 答复 消息 响应 ICMPv6 请 求 回 显 消 息 

无 法 到 达 目 标 主机 发 送 “无 法 到 达 目 标 ” 消 息 ， 通 知 发 送 主机 它们 的 数据 报 或 有 效 负载 无 法 
数据 报 太 大 路 由 器 发 送 “数据 报 太 大 ”消息 ， 通 知 发 送 主 机 数据 报 因 太 大 而 无 法 转发 

超时 路 由 器 发 送 “ 超 时 ”消息 ， 通 知 发 送 主 机 IPv6 ld de se 

参数 问题 路 由 器 在 处 理 IPv6 标 头 或 IPv6 扩展 标 头 时 ， 如 果 遇 到 错误 ， 便 发 送 “ 参 数 问题 ”消息 来 通知 


发 送 主 机 


ICMPv6 与 IPv4 协 议 复 中 的 ICMP 一 样 ， 也 包含 了 一 系列 已 定义 
的 “无 法 到 达 目 标 ?消息 ， 如 表 7-6 所 示 。 


表 7-6 常见 的 ICMPv6 无 法 到 达 目 标 消 息 


无 法 到 达 目 标 消息 说 明 
找 不 到 路 由 路 由 器 在 其 本 地 IPv6 路 由 表 中 找 不 到 指向 目标 IPv6 地 址 的 路 由 时 ， 便 发 送 此 消息 
管理 策略 禁止 通信 当 路 由 器 上 配置 的 某 条 策略 禁止 与 目标 进行 通信 时 ， 路 由 器 便 发 送 此 消息 。 例 如 ， 当 防 


火 墙 丢弃 数据 报时 ， 路 由 器 便 发 送 此 类 消息 
无 法 到 达 目标 地 址 | ”IPv6 路 由 器 无 法 解析 目标 的 MAC 地 址 时 便 发 送 此 消息 

无 小 让 站 当 发 往 目标 UDP 端口 的 、 包 含 UDP 消息 的 IPv6 数据 报 与 正在 侦 听 的 应 用 程序 不 对 应 
目标 端口 无 法 访问 | 时 ， 目 标 主机 便 发 送 此 消息 


2.ND 
ND 是 一 组 ICMPv6 消 息 和 过 程 ， 用 于 确定 相 邻 结 点 间 的 关系 。ND 


取代 了 IPv4 中 使 用 的 ARP、ICMP 路 由 器 发 现 和 ICMP 重 定向 功能 ， 提 供 
了 更 丰富 的 功能 。 主 机 可 以 使 用 ND 完 成 以 下 任务 : 


口 发 现 相 邻 的 路 由 紫 。 


口 发 现 并 自动 配置 地 址 和 其 他 配置 参数 。 


路 由 器 可 以 使 用 ND 完成 以 下 任务 : 


口 公布 它们 的 存在 、 主 机 地 址 和 其 他 配置 参数 。 


口 向 主机 提示 更 好 的 下 一 跃 点 地 址 以 帮助 数据 报 转 发 到 特定 目 


标 。 


结 点 (包括 主机 和 路 由 器 ) 可 以 使 用 ND 完成 以 下 任务 : 


口 解析 IPv6 数 据 报 将 被 转发 到 的 一 个 相 邻 结 点 的 链 路 层 地 址 (又 称 
MAC 地 址 ) 。 


口 动态 公布 MAC 地 址 的 更 改 。 
口 确 定 某 个 相 邻 结 点 是 否 仍 然 可 以 到 达 。 
表 7-7 所 示 为 RFC 2461 解 释文 档 中 描述 的 ND 过 程 。 


表 7-7 1IPv6 邻居 发 现 过程 


邻居 发 现 过 程 说 明 
路 由 器 发 现 主机 通过 该 过 程 来 发 现 它 的 相 邻 路 由 器 
前 组 发 现 主机 通过 该 过 程 来 发 现 本 地 子 网 目标 的 网 络 前 组 
地 址 自动 配置 本 无 论 是 否 存 在 地 址 配 置 服务 器 ( 例 如 运行 动态 主机 配置 协议 版 本 6 (DHCPv6) 的 服务 
器 )， 该 过 程 都 可 以 为 接口 配置 IPv6 地 址 


地 址 解析 结 点 通过 该 过 程 将 邻居 的 IPv6 地 址 解析 为 它 的 MAC 地 址 。IPv6 中 的 地 址 解析 相当 于 
-外 材 T IPv4 中 的 ARP 


结 点 根据 目标 地 址 通过 该 过 程 来 确定 数据 报 要 转发 到 的 下 一 跃 点 IPv6 地 址 。 下 一 跃 点 


F 一 跃 扣 确 定 地 址 可 能 是 目标 地 址 ， 也 可 能 是 某 个 相 邻 路 由 器 的 地 址 

邻居 不 可 访问 性 检测 | ” 结 点 通过 该 过 程 确定 邻居 的 IPv6 层 是 否 能 够 发 送 或 接收 数据 报 

重复 地 址 检测 结 点 通过 该 过 程 确定 它 打算 使 用 的 菜 个 地 址 是 否 已 被 相 邻 节点 占用 
重 定 向 功能 该 过 程 提示 主机 更 好 的 第 一 跃 点 IPv6 地 址 来 帮助 数据 报 向 目标 传送 


IPv6 地 址 解析 包括 交换 邻居 请 求 和 邻居 公布 消息 ， 从 而 将 下 一 跃 
点 IPv6 地 址 解析 为 其 对 应 的 MAC 地 址 。 发 送 主机 在 适当 的 接口 上 发 送 


一 条 多 播 邻居 请 求 消 轧 。 邻居 请 求 消 轧 包括 发 送 世 点 的 MAC 地 址 。 


当 目 标 世 点 接收 到 邻居 请 求 消 思 后， 将 使 用 邻居 请 求 消 息 中 包 合 
的 源 地 址 和 MAC 地 址 的 条 目 更 新 其 邻居 缓存 《相当 于 ARP 缓 存 ) 。 接 
着 ,目标 市 点 向 邻 大 请 求 消息 的 发 送 方 发 送 一 条 包含 它 的 MAC 地 址 的 
单 播 邻居 公布 消 轧 。 


接收 到 来 目 目 标的 邻居 公布 后 ， 发 送 主机 根据 其 中 包含 的 MAC 地 
址 使 用 目标 节点 条 目 来 更 新 它 的 邻居 缓存 。 此 时 ， 发 送 主 机 和 邻居 请 
求 的 目标 惑 可 以 发 送 单 播 IPv6 通 信 量 了 。 


主机 通过 路 由 器 发 现 过 程 会 尝试 发 现 本 地 子 网 上 的 路 由 器 集合 。 
IPV6 路 由 妖 发 现 过 程 如 下 : 


1) IPv6 路 由 器 定期 在 子 网 上 发 送 多 播 路 由 器 公布 消息 ， 以 公布 它 
们 的 路 由 器 身份 信息 和 其 他 配置 参数 〈 例 如 地 址 前 绥 和 默认 路 点 限 
制 ， 汪 


2) 本 地 子 网 上 的 IPv6 主 机 接收 路 由 器 公布 消息 ， 并 使 用 其 内 容 来 
配置 地 址 、 默 认 路 由 器 和 其 他 配置 参数 。 


3) 一 个 正在 启动 的 主机 发 送 多 播 路 由 器 请 求 消息 。 收 到 路 由 器 请 
求 请 恩 后 ， 本 地 子 网 上 的 所 有 路 由 天 都 癌 发 送 路 由 需 请 求 的 主机 发 送 


一 条 单 播 路 由 紫 公 布 消 已 。 该 主机 接收 路 由 占 公 布 消 乱 并 使 用 其 内 容 
来 配置 地 址 、 默 认 路 由 絮 和 其 他 配置 参数 。 


3.MLD 


MLD 是 IPv4 协 议 复 中 的 IGMP 更 新 版 本 ， 是 由 路 由 器 和 节点 交换 的 
一 组 ICMPv6 消 息 ， 供 路 由 器 用 来 为 各 个 连接 的 接口 发 现 有 侦 听 节点 的 
IPv6 多 播 地 址 的 集合 。 与 IGMP 一 样 ，MLD 只 能 发 现 那 些 至 少 包 含 一 个 
侦 昕 屁 的 多 播 地 址 ， 而 不 能 发 现 各 个 多 播 地 址 的 单个 多 播 侦 听 器 的 列 
表 。 与 IGMP 不 同 的 是 ，MLD 使 用 ICMPv6 消 息 而 不 是 定义 它 自己 的 消 
筷 结 构 。MLD 消 息 有 三 种 类 型 ; 


口 多 播 侦 听 融 查 询 : 路 由 万 使 用 多 播 侦 听 融 碍 询 消息 来 查询 子 网 
上 是 否 有 多 播 侦 听 能 。 


口 多 播 侦 听 豆 报 筷 : 多 播 侦 听 噩 使 用 多 播 侦 听 右 报 告 消息 来 报告 
它们 有 兴趣 接收 发 往 特定 多 播 地 址 的 多 播 通信 量 ， 或 者 使 用 这 类 消息 
来 啊 应 多 播 侦 听 融 查询 消息 。 


口 多 播 侦 听 融 完 成 : 多 播 侦 听 瑚 使 用 多 播 侦 听 亏 完 成 消 轧 来 报告 
它们 可 能 是 子 网 上 最 后 的 多 播 组 成 员 。 


7.4 路 由 和 路 由 算法 


网 络 层 的 主要 功能 束 古 将 分 组 从 源 市 点 路 由 到 目的 节点 中 ， 而 且 
在 大 多 数 计算 机 网 络 中 ， 采 用 的 是 数 据 报 分 组 交换 方式 ， 数 据 报 分 组 
需要 经 过 多 跳 \Hop， 也 就 是 要 经 过 多 少 个 路 由 器 ) 才能 到 达 目 的 地 
的 。 


路 由 功能 其 实 是 一 种 数据 报 分 组 交换 路 径 选 择 行 为 ， 是 网 络 层 的 
一 种 基本 功能 。 路 由 功能 与 我 们 旅行 或 者 运输 货物 选择 最 佳 〈 注 
意 , “最 佳 "并 不 代表 最 快 ， 是 要 综合 考虑 的 ) 路 线 是 一 个 道理 。 图 7-22 
所 示 的 是 我 们 假设 要 从 北京 发 一 封 邮件 到 美国 的 旧金山 朋友 那里 的 示 
例 。 


rr 


> 
如 何 把 这 封 信和 发 
往 旧 金山? 
es Es 2 至 旧金山 
| ~ 处 S -4 A 
| 旧金山 多 


可 选 路 径 

。 北 京 一 旧金山 

。 北京 一 东京 一 旧金山 

* 北京 一 上 海 一 东京 一 旧金山 


图 7-22 为 "路 由 ?功能 打 的 一 个 比方 


从 图 中 可 以 看 出 ， 发 这 样 一 封 信 可 以 有 多 条 路 线 ， 不 同 路 线 又 需 
采用 不 同 的 邮寄 方式 、 不 同 的 线路 长 度 和 邮寄 时 间 ， 当 然 运 输 成 本 也 
各 不 一 样 ， 最 终 选 择 哪 条 线路 要 综合 总 体 邮 寄 成 本 、 邮 寄 时 间 和 途经 
邮局 的 可 靠 性 等 方面 进行 考虑 。 路 由 选择 也 是 一 样 时 ， 它 要 综合 考虑 
许多 因素 的 ， 如 线路 长 度 、 信 道 带宽 、 线 路 的 稳定 性 、 途 经 端口 的 开 
销 等 。 不 同 的 路 由 算法 所 考虑 的 因素 并 不 一 样 ， 这 些 将 在 本 章 后 面 介 


绍 。 


7.4.1 路 由 的 分 类 


路 由 (Routing) 是 把 信息 从 源 节 点 通过 网 络 传递 到 目的 节点 的 行 
为 ， 价 单 地 讲 路 由 就 是 指 三 层 设 备 从 一 个 接口 上 收 到 数据 包 ， 根 据 数 
据 包 的 目的 地 址 进行 定 同 ， 并 转发 到 另 一 个 接口 的 过 程 。 但 在 这 条 路 
由 路 径 上 ， 至 少 需要 遇 到 一 个 中 间 结 点 ， 那 就 是 提供 路 由 功能 的 设 
备 ， 如 路 由 疹 和 三 层 交 换 机 。 路 由 与 桥接 对 比 的 主要 区 别 在 于 ， 桥 接 
发 生 在 OSI 参考 协议 的 第 二 层 (链接 层 ) ， 连 接 的 是 同一 网 络 或 同一 子 
网 的 不 同 网 段 ， 而 路 由 发 生 在 第 三 层 (网 络 层 ) ， 连 接 的 是 不 同 网 络 
或 不 同 于 网 。 


路 由 功能 的 实现 是 依 徘 路 由 絮 或 三 层 交 换 机 中 的 路 由 表 进 行 的 。 
路 由 又 分 静态 路 由 (Static Routing) 和 动态 路 由 (Dynamic Routing) 
两 大 类 。 下 面 分 别 予 以 介绍 。 


静态 路 由 是 我 们 经 常 需要 配置 的 ， 特 别 是 在 小 型 局 域 网 中 ， 因 为 
它 配 置 和 管理 都 比较 商 单 。 总 体 来 说 ， 静 仿 路 由 具有 以 下 几 个 方面 的 


特点。 


(1) 手动 配置 


静态 路 由 需要 管理 员 根 据 实 际 需要 一 条 条 目 己 手动 配置 ， 路 由 需 
` 会 目 动 生成 所 需 的 静态 路 由 。 静 态 路 由 中 包括 目的 节点 或 目的 网 络 


的 下 地 址 ， 及 数据 包 从 当前 路 由 需 开 始 路 由 的 第 一 个 下 一 跳 (通常 就 
是 网 关 ) 所 对 应 的 接口 或 1P 地 址 。 


(2) 路 由 路 径 固 定 不 变 


因为 静态 路 由 十 手动 配置 的 ， 且 静态 的 ， 所 以 当 网 络 的 拓扑 结构 
或 链 路 的 状态 发 生变 化 时 ， 这 些 静 态 路 由 不 能 目 动 修改 ， 需 要 网 络 管 
理 员 手 工 去 修改 路 由 表 中 相关 信息 。 


(3) 不 可 通告 性 


静态 路 由 信息 在 默认 情况 下 是 私有 的 ， 不 会 通告 给 其 他 路 由 器 ， 
也 束 是 当 在 一 个 路 由 紫 上 配置 了 某 条 前 仿 路 由 时 ， 它 不 会 被 通告 网 络 
中 相连 的 其 他 路 由 器 。 但 网 络 管理 员 可 以 通过 重新 发 布 静 态 路 由 为 其 
他 动态 路 由 ， 使 得 网 络 中 其 他 路 由 瑚 也 可 获 此 静态 路 由 。 


(4) 单身 性 


静态 路 由 是 具有 单 问 性 的 ， 也 就 是 它 仅 为 数据 提供 沿 着 下 一 跳 的 
方 同 进行 路 由 ， 不 提供 反 辣 路 由 。 所 以 如 琳 你 想 要 使 源太 点 与 目的 市 
点 或 网 络 进行 双向 通信 ， 就 必须 同时 配置 回程 静态 路 由 。 在 现实 应 用 
中 经 解 会 遇 到 这 样 的 问题 ， 束 是 明明 配置 了 到 达 某 点 的 静态 路 由 ， 
可 还 是 Ping 不 通 ， 其 中 一 个 重要 原因 融 是 没有 配置 回程 静态 路 由 。 


如 图 7-23 所 示 ， 如 果 想 要 使 得 PC1 (PC1 已 配置 了 A 节点 的 IP 地 址 
10.16.1.2/24 作 为 网 关 地 址 ) 能 够 Ping 通 PC2， 则 必须 同时 配置 以 下 两 条 
静态 路 由 ， 具 体 配置 方法 在 此 不 作 介绍 。 


Q@ 正 向 路 由 


10.16.1.2/24 10.16.2.2/24 10.16.3.2/24 
PC ”| 国 3 ES 国史 Pc> 
P= A B C D ~ 
> RI1 R2 > 
10.16.1.1/24 10.16.2.1/24 10.16.3.1/24 


@@ 回 程 路 由 


图 7-23 鹃 态 路 由 单 向 性 示例 


正 向 路 由 : 在 R1 路 由 器 上 配置 了 到 达 PC2 的 正 向 静态 路 由 (以 PC2 
10.16.3.2/24 作 为 目的 节点 ， 以 C 结 点 IP 地 址 10.16.2.2/24 作 为 下 一 跳 地 
址 ) ，; 


回程 路 由 : 在 R2 路 由 器 上 配置 一 条 到 达 PC1 的 回程 静态 路 由 (以 
PC1 10.16.1.1/24 作 为 目的 节点 ， 以 B 结 点 IP 地 址 10.16.2.1/24 作 为 下 一 跳 
地 址 ) ， 以 提供 Ping 过 程 回 程 ICMP 消 息 的 路 由 路 径 。 


(5) 接力 性 


如 采 某 条 静态 路 由 中 间 经 过 的 跳 数 大 于 1 (也 就是 整 条 路 由 路 径 经 
历 了 三 个 或 以 上 路 由 器 结 点 ) ， 则 必须 在 除 最 后 一 个 路 由 器 外 的 其 他 
路 由 右上 依次 配置 到 达 相 同 目 的 节操 或 目的 网 络 的 静态 路 由 ， 这 束 是 
静态 路 由 的 接力 性 ， 人 否则 仅 在 源 路 由 闫 上 配置 静态 路 由 还 是 不 可 以 
EE 


距 像 你 要 从 长 沙 到 北京 去 ， 假 设 中 间 要 途经 的 站 点 包括 : 武汉 - 郑 
州 -石家庄 ， 可 人 家 只 告诉 你 目的 地 是 北京 ， 以 及 从 长 沙 出 发 的 下 一 站 
是 武汉 。 对 于 一 个 没有 多 少 旅 游 经 验 的 人 来 说 ， 你 不 可 能 知道 到 了 武 
汉 后 又 该 如 何 走 ， 必 须 有 人 告诉 你 到 了 武汉 后 再 怎么 走 ， 到 了 郑州 后 
D1 这 束 是 接力 性 。 


图 7-24 所 示 是 一 个 三 个 路 由 器 串联 的 简单 网 络 ， 各 个 路 由 器 结 点 及 
PC 机 的 IP 地 址 均 在 图 中 进行 了 标注 ，PC1 已 配置 好 指向 R1 的 A 结 点 地 址 
的 网 关 ， 现 假设 要 使 PC1 能 Ping 得 通 PC2， 则 需要 配置 以 下 四 条 路 由 
(两 条 正 向 ， 两 条 回程 ) : 


@ 回 程 路 由 


@@ 正 向 路 由 
2 


" - 


Ee 10.16.3.1/24 "ih 
@ 正 同 接 力 路 由 


es 1/24 10.16.2.1/24 


@ 回 程 接力 路 由 


图 7-24 静态 路 由 接力 性 示例 


GD: 在 R1 路 由 器 上 配置 了 到 达 PC2 的 正 向 静态 路 由 (以 PC2 
10.16.4.2/24 作 为 目的 结 点 ， 以 C 结 点 IP 地 址 10.16.2.2/24 作 为 下 一 跳 地 
址 ) 。 


@: 在 R2 路 由 器 上 配置 了 到 达 PC2 的 正 向 接力 静态 路 由 (同样 以 
PC2 10.16.4.2/24 作 为 目的 节点 ， 以 E 结 点 也 地 址 10.16.3.2/24 作 为 下 一 跳 
地 址 ) 。 


(3): 在 R3 路 由 器 上 配置 一 条 到 达 PC1 的 回程 静态 路 由 (以 PC1 
10.16.1.1/24 作 为 目的 节点 ， 以 D 结 点 卫 地 址 10.16.3.1/24 作 为 下 一 跳 地 
址 ) ， 以 提供 Ping 过 程 回程 ICMP 消 息 的 路 由 路 径 。 


由: 在 R2 路 由 器 上 配置 一 条 到 达 PC1 的 回程 接力 静态 路 由 (同样 以 
PC1 10.16.1.1/24 作 为 目的 节点 地 址 ， 以 B 结 点 IP 地 址 10.16.2.1/24 作 为 下 
一 跳 地 址 ) ， 以 提供 Ping 过 程 回程 ICMP 消 息 的 接力 路 由 路 径 。 


(6) 优先 级 较 高 


因为 静态 路 由 明确 指出 了 到 达 目 的 网 络 ， 或 者 目的 节点 的 路 由 路 
径 ， 所 以 在 所 有 同 目的 地 址 的 路 由 中 ， 静 念 路 由 的 优先 级 是 除 “ 直 连 路 
由 ”外 最 高 的 ， 也 就 是 如 有 果 配 置 了 到 达 某 一 网 络 或 者 某 一 结 点 的 静态 路 
由 ， 则 优先 采用 这 条 静态 路 由 ， 只 有 当 这 条 衣 仿 路 由 不 可 用 时 才 会 考 
虑 选择 其 他 的 路 由 。 


说 明 ”在 这 里 要 特别 注意 一 个 方面 ， 那 就 是 默认 路 由 的 优先 级 。 
如 果 在 一 个 路 由 器 同时 有 一 条 目的 地 址 相同 的 静态 路 由 和 一 条 默认 路 
由 ， 则 首先 选择 的 是 静态 路 由 。 要 使 对 应 的 默认 路 由 起 作用 ， 束 必须 
删除 相同 目的 网 络 或 目的 节操 的 静态 路 由 ， 否 则 会 冲突 ， 默 认 路 由 不 
起 作用 。 


(7) 适用 小 型 网 络 


静态 路 由 一 般 适 用 于 比较 简单 的 小 型 网 络 环境 ， 因 为 在 这 样 的 环 
境 中 ， 网 络 管 理 员 兄 于 清楚 地 了 解 网 络 的 拓扑 结构 ， 便 于 设置 正确 的 
路 由 信息 。 同 时 小 型 网 络 所 需 配 置 的 静态 路 由 条 目 不 会 太 多 。 如 果 网 
络 规 模 较 大 ， 拓 扑 结构 比较 复 洒 ， 则 不 宜 采 用 静态 路 由 ， 因 为 这 样 的 
配置 工作 量 实在 太 大 。 


2. 动 态 路 由 


静 仿 路 由 对 于 小 型 且 变 化 不 是 很 频 粽 的 网 络 来 说 还 古 可 行 的 ， 如 
局 域 网 。 但 是 对 于 较 大 型 的 广域网 来 说 ， 由 于 拓扑 结构 较 复 杂 ， 且 网 
络 结构 可 能 经 单 变动 ， 静 仿 路 由 束 不 再 适用 了 ， 通 间 采 用 更 加 灵活 ， 
更 具 目 动 特性 的 动态 路 由 。 总 体 来 说 ， 动 仿 路 由 具有 以 下 几 个 方面 的 


特点: 


(1) 自动 生成 


动态 路 由 的 一 个 最 重要 特点 融 是 在 网 络 中 某 条 路 由 所 包括 的 路 由 
妖 同 时 局 动 了 某 种 动态 路 由 协议 ， 通 告 了 各 日 所 直接 连接 的 网 络 后 ， 
则 这 些 路 由 夯 间 融会 目 动 生 成 这 些 路 由 硕 直 接连 接 的 网 络 间 的 路 由 表 
项 ， 管 理 员 无 须 一 一 手动 创建 。 这 对 于 较 大 型 的 网 络 来 说 ， 是 最 方 
便 、 最 简单 的 路 由 碗 择 了 。 


(2) 自动 调整 


当 网 络 结构 发 生 改变 ， 我 们 手动 的 静态 配置 也 往往 无 法 及 时 跟着 
改变 ， 但 动态 路 由 可 以 随时 根据 网 络 拓扑 结构 的 变化 调整 路 由 表 项 ， 
同时 还 会 目 动 删除 无 效 的 动态 路 由 表 项 ， 更 加 方便 路 由 管理 。 


(3) 自动 通告 


前 面 说 了 ， 一 个 路 由 器 上 的 静 仿 路 由 表 项 是 一 个 路 由 右 私 有 的 ， 
但 十 动态 路 由 可 以 在 相 邻 路 由 髓 上 相互 通告 ， 以 便 及 时 反映 拓扑 结构 


的 变化 ， 生 成 新 的 动态 路 由 表 项 。 


(4) 自动 生成 双向 路 由 


里 然 单 条 动态 路 由 也 是 单 向 的 ， 但 是 路 由 器 在 生成 菜 条 路 径 的 动 
仿 路 由 时 会 日 动 生成 回程 路 由 表 项 ， 也 就 是 会 同时 双 同 路 由 表 项 。 


(5) 仅 可 生成 网 络 间 的 路 由 表 项 


动态 路 由 仪 可 生成 各 路 由 器 所 直接 连接 的 各 个 网 络 或 于 网 间 的 路 
由 表 项 ， 不 能 生成 到 达 具 体 季 点 或 主机 的 动态 路 由 表 项 ， 如 采 仅 需 要 
生成 到 达 某 个 结 点 或 主机 的 路 由 ， 则 需要 选择 静态 路 由 。 


(6) 不 同 动态 路 由 不 兼容 


动态 路 由 根据 所 采用 的 路 由 算法 的 不 同 又 可 分 为 多 种 类 型 ， 如 RIP 
(路 由 信息 协议 ) 、OSPF (开放 最 短路 人 径 优先 ) 、EIGRP (增强 内 部 
网 关 路 由 协议 ) 、IS-IS (中 间 系 统 到 中 间 系 统 ) 、BGP (边界 网 关 协 
议 ) 等 。 不 同 的 动态 路 由 协议 主要 适用 的 网 络 环境 不 一 样 ， 也 是 不 兼 
容 的 ， 但 可 以 进行 相互 重 发 布 ， 具体 将 在 本 章 后 面 介 绍 。 


7.4.2 ”路 由 算法 基础 


路 由 算法 (Routing Algorithm) 是 在 给 定 一 组 路 由 器 及 连接 路 由 器 
链 路 的 情况 下 ， 找 出 一 条 从 源太 上 后 到 目标 太 操 的 最 佳 路 径 。 通 俗 地 
讲 ， 束 是 把 略 由 器 选择 最 佳 路 径 的 策略 称 为 路 由 算法 ， 是 路 由 器 的 关 
键 功 能 所 在 。 为 了 完成 这 项 工作 ， 在 路 由 器 中 需要 收集 和 保存 着 各 种 
与 传输 路 径 的 相关 数据 ， 如 拓扑 结构 、 端 口 度量 、 端 口 速率 等 ， 然 后 
根据 相应 的 路 由 算法 生成 一 个 个 路 由 表 (RoutingTable) 表 项 ， 在 数据 
包 转 发 时 提供 路 由 选择 。 


从 大 的 方面 来 说 ， 路 由 算法 可 以 分 为 非 自 适应 路 由 算法 
(Nonadaptive Algorithm) 和 自 适 应 路 由 算法 (Adaptive Algorithm) 两 
类 。 非 自 适 应 路 由 算法 的 典型 代表 就 是 我 们 常 说 的 静态 路 由 ， 但 不 仪 
于 此 。 而 动态 路 由 中 所 采用 的 算法 都 属于 自 适 应 路 由 算法 。 


1. 非 目 适 应 路 由 算法 


非 目 适应 路 由 算法 十指 那些 不 能 根据 网 络 流量 和 拓扑 结构 的 变化 
更 新 路 由 表 ， 仅 使 用 静态 路 由 表 的 路 由 算法 ， 又 称 固 定式 路 由 选择 算 
法 。 非 目 适 应 路 由 算法 的 特点 是 简单 、 开 销 少 、 灵 活性 老 。 它 主要 包 
括 静 态 路 由 (Static Routing) 、 扩 散 (Flooding) 法 、 随 机 走动 


(Random Walk) 法 、 最 短路 径 (Shortest Path) 法 、 基 于 流量 的 路 由 
(Flow-based Routing) 法 。 下 面 分 别 予 以 简单 介绍 。 


(1) 静态 路 由 


静态 路 由 一 般 不 认为 是 真正 的 路 由 算法 ， 它 是 由 管理 员 在 路 由 咒 
上 手动 一 条 条 创建 的 路 由 表 项 。 在 静态 路 由 表 项 中 包括 目的 节点 或 网 
络 IP 地 址 、 下 一 跳 IP 地 址 或 接口 。 具 体 参 见 上 市 介绍 。 我 们 通 第 所 说 的 
路 由 算法 一 般 不 包括 静态 路 由 算法 ， 因 为 静态 路 由 只 是 在 开始 路 由 前 
由 管理 人 员 手 动 建立 的 静态 映射 表 项 ， 不 能 对 网 络 改变 做 出 反映 ， 通 
常 修 认 为 不 适用 于 现在 的 大 型 、 吻 变 的 网 络 。 


(2) 扩散 法 


扩散 法 是 当 一 个 路 由 如 接口 收 到 一 个 报 文 分 组 后 ， 即 问 它 所 有 接 
口 (包括 接收 该 分 组 的 源 接口 ) 进行 复制 扩散 。 因 为 有 多 条 可 能 的 路 
径 ， 所 以 即使 网 络 局 部 出 现 了 故障 也 不 影响 通信 ， 但 大 量 重复 分 组 加 
重 了 网 络 负 担 。 正 因 如 此 ， 这 种 路 由 算法 适宜 于 网 络 规模 小 、 通 信和 负 
载 轻 、 可靠 性 要 求 极 高 的 通信 场合 ， 如 军用 通信 中 。 


(3) 随机 走动 法 


随机 走动 法 是 当 结 点 收 到 分 组 后 ， 向 所 有 与 之 相 邻 的 结 点 中 随机 
选择 出 一 个 将 分 组 转发 出 去 。 因 为 分 组 会 在 网 络 中 乱 定 ， 所 以 路 由 可 


达 的 概率 还 比较 高 。 这 种 方法 虽然 简单 ， 但 不 是 最 佳 路 由 ， 通 信 效 率 
低 ， 分 组 传输 延迟 也 不 可 预测 ， 实 用 价值 低 。 


(4) 最 短路 径 法 


一 般 来 讲 ， 即 使 网 络 节 点 直接 相连 ， 传 输 时 延 也 各 不 一 样 ， 这 和 与 
线路 质量 、 网 络 结 点 忙 与 内 的 状态 ， 结 反 处 理 能 力 等 很 多 因素 有 大 。 
定量 分 析 中 ， 常 用 开销 最 小 作为 网 络 结 点 之 间 选 择 的 依据 ， 结 点 间 的 
传输 时 延 古 决定 费用 的 主要 因素 。 


最 短路 径 法 是 由 Dijkstra 提 出 的 ， 其 基本 思想 是 : 将 源 节 点 到 网 络 
中 所 有 结 点 的 最 短 通路 都 找 出 来 ， 作 为 这 个 结 点 的 路 由 表 。 当 网 络 的 
拓扑 结构 不 变 、 通 信和 量 平稳 时 ， 该 点 到 网 络 内 任何 其 他 结 点 的 最 住 路 
径 都 在 它 的 路 由 表 中 。 如 果 每 一 个 结 点 都 生成 和 保存 这 样 一 张 路 由 
表 ， 则 整个 网 络 通信 都 在 最 佳 路 径 下 进行 。 每 个 结 点 收 到 分 组 后 ， 查 
表决 定向 哪个 后 继 结 点 转发 。 


(5) 基于 流量 的 路 由 算法 


最 短路 径 算法 是 只 考虑 网 络 拓扑 结构 来 寻找 最 短路 径 ， 没 有 考虑 
网 络 流量 、 负 载 对 路 由 选择 的 影响 ， 而 基于 流量 的 路 由 算法 则 结合 了 
网 络 拓扑 结构 和 通信 流量 两 方面 的 因素 进行 路 由 选择 。 它 需要 先知 道 
网 络 拓 扑 结构 、 结 后 之 间 的 平均 流量 、 各 条 线路 的 容量 ， 然 后 在 此 基 
础 上 采用 适当 的 选择 算法 ， 从 而 找 出 最 佳 路 由 。 基 于 流量 的 路 由 算法 


的 基本 原理 是 根据 知道 一 条 线路 的 负 倚 和 平均 流量 ， 用 排队 计算 出 该 
线路 的 分 组 平均 时 延 ， 再 由 所 有 线路 的 平均 时 延 直 接 计 算出 流量 加 权 
平均 值 ， 从 而 得 到 整个 网 络 的 平均 分 组 时 延 。 此 方法 可 使 网 络 通信 量 
更 加 平衡 ， 得 到 较 小 的 平均 分 组 时 延 。 


2. 目 适应 路 由 算法 


我 们 通 闻 所 说 的 动态 路 由 均 属 于 目 适应 路 由 算法 类 型 ， 可 根据 网 
络 流量 和 拓扑 结构 的 变化 更 新 路 由 表 。 特 点 是 开销 大 、 健 壮 性 好 和 有 灵 
活性 好 。 在 这 类 路 由 算法 中 ， 路 由 融 又 是 如 何 收集 网 络 拓扑 结构 和 端 
口 信息 ， 然 后 确定 最 佳 路 由 呢 ? 这 要 依据 不 同 的 动态 路 由 协议 所 采用 
的 动态 路 由 算法 类 型 而 定 。 


总 体 来 说 ， 这 些 动态 路 由 协议 中 ， 主 要 有 两 种 动态 路 由 算法 : 总 
体式 路 由 算法 和 分 散 式 路 由 算法 。 采 用 分 散 式 路 由 算法 时 ， 每 个 路 由 
丹 只 与 直接 相连 的 路 由 器 交换 路 由 信息 ， 每 个 路 由 器 只 有 相 邻 路 由 器 
的 路 由 信息 ， 而 没有 网 络 中 的 其 他 路 由 器 的 路 由 信息 ， 其 代表 就 是 “ 距 
离 矢 量 ”(Distance Vector，DV) 算法 。 而 采用 总 体式 路 由 算法 时 ， 每 
个 路 由 器 都 拥有 网 络 中 某 个 区 域 或 者 整个 网 络 中 所 有 其 他 路 由 器 的 全 
部 信息 以 及 网 络 的 流量 状态 ， 其 代表 包括 链 路 状态 (Link State，LS) 
算法 和 分 级 路 由 (Hierarchical Routing) 算法 。 


(1) 距离 天 量 路 由 算法 


距离 矢量 简单 地 讲 就 是 有 方向 的 距离 ， 也 就 是 对 应 路 由 条 目 中 源 
和 目的 站 点 间 的 距离 。 这 个 距离 就 是 指 跳 数 (hop) ， 或 者 叫 度量 
(Metric) ， 从 本 结 点 起 ， 每 经 过 一 个 路 由 器 (也 可 以 是 提供 路 由 功能 
的 三 层 交 换 机 ， 下 同 ) ， 就 加 一 跳 。 也 就 是 对 应 路 由 条 目 中 除 源 站 点 
所 在 网 络 直 接连 接 的 路 由 器 外 ， 到 达 目 的 站 点 所 经 过 的 路 由 器 数 (路 
径 中 所 有 路 由 器 数 减 1) 。 图 7-25 所 示 为 一 个 四 台 路 由 器 串联 的 网 络 示 
例 ， 图 中 从 PC1 到 达 PC2 的 路 由 条 目的 跳 数 (也 就 是 距离 》 为 3 ( 共 经 
过 四 个 路 由 器 ， 减 1 后 得 到 3) 。 但 是 PC3 到 达 PC2 的 跳 数 就 只 有 1 了 
( 共 经 过 2 个 路 由 器 ， 减 1 后 得 到 1) ， 因 为 它们 两 个 之 间 除 了 源 路 由 器 
外 ， 只 经 过 了 一 个 路 由 器 。 在 这 里 要 特别 注意 的 是 ， 跳 数 是 针对 所 经 
过 的 路 由 器 数 而 言 的 ， 而 不 是 所 经 过 的 网 络 数 而 言 的 ， 因 为 连接 在 同 
一 路 由 器 的 各 个 网 络 之 间 是 没有 跳 数 的 ， 也 即 跳 数 为 0。 
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图 7-25 距离 矢量 计算 示例 


采用 距离 矢量 算法 的 典型 路 由 协议 就 是 RIP， 但 它 规 定 一 条 RIP 路 
由 中 最 多 只 能 15 跳 ， 超 过 这 个 数 就 认为 路 由 不 可 达 。 其 他 采用 距离 天 
量 算法 的 路 由 协议 有 IGRP 《内 部 网 关 路 由 协议 ) 、EIGRP (增强 型 内 


部 网 关 路 由 协议 ) 和 BGP (边界 网 关 协 议 ) ， 但 EIGRP 同 时 还 支持 “ 链 
路 状态 ”路 由 算法 。IGRP 和 EIGRP 的 最 大 跳 数 均 为 255， 比 RIP 的 15 大 了 
许多 ，BGP 更 没有 最 大 跳 数 限制 ， 所 以 可 以 适用 于 更 大 的 网 络 。 


(2) 链 路 状态 路 由 算法 


链 路 状态 算法 (又 称 最 短路 径 优先 算法 ) 比较 复杂 ， 它 不 仅 是 要 
根据 所 经 过 的 路 由 右 多 少 ， 还 要 根据 路 径 中 各 有 段 链 路 的 状态 来 计算 最 
主 路 由 路 径 。 而 这 个 链 路 状态 包括 : 接口 的 IP 地 址 、 子 网 掩 码 、 网 络 
类 型 《如 以 太 网 链 路 或 串 行 点 对 点 链 路 ) 、 该 链 路 的 端口 开销 

(Cost) 、 该 链 路 上 的 所 有 的 相 邻 路 由 器 。 而 端口 开销 又 与 端口 的 接 入 


市 竟 有 关 。 


采用 链 路 状态 路 由 算法 的 动态 路 由 协议 主要 包括 OSPF (开放 最 短 
路 径 优 先 ) 、IS-IS (中 间 系 统 到 中 间 系 统 ) 、EIGRP (同时 支持 “ 链 路 
状态 "和 “距离 矢量 ”两 种 算法 ) 。 


总 体 而 言 ， 链 路 状态 路 由 协议 征 层次 却 的 ， 网 络 中 的 路 由 噩 并 不 
癌 邻 居 路 由 紫 传 递 路 由 表 项 ， 只 是 同 邻居 路 由 右 通 告 它 的 一 些 链 路 状 
态 。 在 这 类 路 由 协议 网 络 中 ， 会 把 网 络 中 的 所 有 路 由 器 分 成 区 域 ， 收 
集 区 域 的 所 有 路 由 右 的 链 路 状态 信息 ， 然 后 根据 状态 信息 生成 网 络 拓 
扑 结 构 ， 最 后 每 一 个 路 由 絮 再 根据 拓扑 结构 计算 出 路 由 。 而 距离 矢量 
路 由 协议 是 平面 式 的 ， 所 有 的 路 由 学 习 完全 依靠 邻居 路 由 背 ， 区 换 的 


征 完 整 的 路 由 表 项 。 所 以 链 路 状态 路 由 协议 更 灵活 ， 更 适合 大 型 的 网 


\NS 
mm 
O 


以 上 介绍 的 距离 天 量 和 链 路 状态 路 由 算法 其 实 只 是 针对 一 个 特定 
的 区 域 而 言 的 ， 还 有 一 种 是 针对 整个 网 络 来 说 的 路 由 算法 ， 那 融 是 下 
面 将 要 介绍 的 分 级 路 由 算法 。 


(3) 分 级 路 由 算法 


在 前 面 介 绍 的 距离 天 量 和 链 路 状态 路 由 算法 中 ， 每 个 路 由 器 都 需 
要 保存 其 他 路 由 句 的 一 些 信息 。 随 着 网 络 规 模 的 扩大 ， 网 络 中 的 路 由 
妖 也 将 增加 。 因 此 ， 路 由 表 的 规模 也 将 增 大 ， 从 而 使 路 由 器 不 能 有 效 
地 人 处理 网 络 流 量 。 使 用 分 级 路 由 (Hierarchical Routing) 算法 可 以 解决 


这 个 问题 。 


在 分 级 路 由 算法 中 ， 路 由 顺 被 分 成 很 多 组 ， 称 为 区 域 。 每 个 路 由 
吉 都 只 有 目 己 所 在 区 域 路 由 器 的 信息 ， 而 没有 其 他 区 域 路 由 器 的 信 
息 。 所 以 在 其 路 由 表 中 ， 路 由 器 只 需要 存储 其 他 每 个 区 域 的 一 条 记 
录 。 应 用 这 种 路 由 算法 的 典型 路 由 协议 包括 OSPF、IS-IS、BGP。 而 在 
前 面 已 说 到 ， 这 些 路 由 协议 已 采用 了 距离 矢量 或 链 路 状态 路 由 算法 ， 
这 只 是 针对 区 域内 部 而 言 ， 在 整个 网 络 中 ， 还 是 要 采用 分 级 路 由 算法 
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以 上 这 些 路 由 算法 工作 原理 将 在 本 章 再 具体 介绍 。 


7.4.3 ”路 由 表 基 础 


路 由 表 (Routing Table) 是 一 个 存储 在 路 由 器 或 者 联网 计算 机 中 
的 电子 表格 (文件 或 类 似 的 数据 库 。 路 由 表 存 储 着 指向 特定 网 络 地 
址 的 路 径 (在 有 些 情况 下 ， 还 记录 有 路 径 的 路 由 度量 值 ) ， 含 有 网 络 
周边 的 拓扑 信息 。 路 由 表 建 立 的 主要 目标 是 为 了 实现 路 由 协议 和 静态 
路 由 选择 。 路 由 器 通常 依靠 所 建立 及 维护 的 路 由 表 来 决定 如 何 转 发 。 
路 由 表 能 力 是 指 路 由 表 内 所 容纳 路 由 表 项 数量 的 极限 。 


无 论 是 静态 路 由 ， 还 是 各 种 动态 路 由 ， 都 会 在 路 由 万 的 路 由 表 中 
保存 ， 但 是 不 同类 型 的 路 由 表 所 显示 的 信息 不 完全 相同 。 由 设备 管理 
员 事 先 手 动 创建 的 固定 路 由 表 称 为 静态 路 由 表 ， 它 不 会 随 示 来 网 络 结 
构 的 改变 而 改变 。 动 态 路 由 表 是 路 由 器 根据 所 选择 的 动态 路 由 协议 算 
法 目 动 生成 的 路 由 表 。 


要 特别 注意 的 是 ， 除 了 前 面 所 说 的 静态 路 由 和 动态 路 由 外 ， 还 有 
一 种 路 由 一 一 直 连 路 由 ， 在 这 种 路 由 器 上 直接 连接 网 络 (不 表示 具体 
主机 的 路 由 ) 。 因 为 连接 在 同一 个 路 由 器 上 的 各 个 网 络 都 是 相通 的 ， 
无 须 配 置 任何 其 它 路 由 条 目 ， 只 需要 在 路 由 右上 进行 通告 即 可 。 


在 路 由 器 的 路 由 表 中 ， 不 同 路 由 的 代码 (Codes) 是 不 一 样 的 。 在 
Cisco 路 由 絮 上 只 需要 执行 show ip route 命 令 即 可 显示 当前 路 由 恬 的 路 


由 表 中 所 有 路 由 表 项 ， 并 且 在 最 前 面 显示 了 不 同 路 由 的 代码 ，C 代 表 
O 代 表 
OSPF 路 由 ，R 代 表 RIP 路 由 等 。 男 外 “S*” 代 表 的 是 默认 路 由 ( 它 的 目 
的 地 址 是 为 任意 地 址 0.0.0.000) ， 世 是 静态 路 由 的 一 种 。 具 体 如 下 。 


直 连 路 由 ，S 代 表 静 态 路 由 ，I 代 表 IGRP 路 由 ，B 代 表 BGP 路 由 ， 


R1#Sshow ip route 
Codes:C-connected,S-static,I-IGRP,R-RIP,M-mobile,B-BGP 
D-EIGRP, EX-EIGRP external,O0-OSPF,IA-OSPF inter area 
N1-OSPF NSSA external type 1,N2-0OSPF NSSA external type 2 
E1-OSPF external type 1,E2-OSPF external type 2,E-EGP 


i-IS-IS,L1-IS-IS level-1,L2-IS-IS level-2,*-candidate default 


U-per-user static route,o-ODR 

Gateway of last resort is 0.0.0.0 to network 0.0.0.0 
192.168.10.0/30 is subnetted,1 subnets 

C 192.168.10.0 is directly connected,Serial3/0 
192.168.20.0/30 is subnetted,1 subnets 

C 192.168.20.0 is directly connected,Serial3/3 
172.31.0.0/24 is subnetted,1 subnets 

S 172.31.10.0 [1/0] via 192.168.20.2,Serial3/3 

S* 0.0.0.0/0 is directly connected,Serial3/0 


每 个 静态 路 由 表 项 至 少 包 括 以 下 信息 : 


口 网 络 ID: 就 是 目的 地 址 的 网 络 IP 地 址 。 


口子 网 掩 码 (subnet mask) : 用 来 判断 目的 网 络 IP 所 属 的 网 络 ， 
一 般 是 以 地 址 前 级 长 度 来 表示 的 ， 如 上 面 示例 中 的 192.168.10.0/30， 


示 失 码 长 度 为 30 位 ， 对 应 的 子 网 掩 码 就 为 255.255.255.252。 


口 下 一 跳 地 址 /接口 (Next hop/interface) : 就 是 数据 在 发 送 到 目 


标 地 址 的 “旅途 ”中 下 一 站 的 地 址 。 


表 


其 他 类 型 的 路 由 表 项 的 显示 各 不 相同 ， 有 具体 大 家 可 以 参见 笔者 编 
著 的 《路 由 器 配置 与 管理 完全 手册 一 一 Cisco 篇 》 和 《路 由 器 配置 与 管 
理 完全 手册 一 _H3C 篇 》。 


经 验 之 谈 ”路 由 表 十 适用 于 整个 路 由 器 的 ， 而 不 是 仅 适用 于 具体 
的 个 别 路 由 絮 接 口 的 。 也 就 是 说 ， 路 由 表 中 的 每 一 个 表 项 部 适用 于 来 
目 本 路 由 器 上 任何 接口 ， 符 合 路 由 策略 特性 的 数据 包 进 行路 由 ， 而 不 
只 是 适用 于 对 来 目 某 个 具体 的 接口 上 的 数据 包 进 行路 由 。 所 以 我 们 在 
Cisco 路 由 器 中 为 路 由 器 配置 路 由 时 ， 是 在 “全 局 配置 模式 ”或 “路 由 器 
配置 模式 ”下 进行 的 ， 在 华为 、H3C 路 由 器 中 是 在 “系统 视图 ”下 进行 ， 
都 不 是 在 具体 的 “接口 配置 模式 ”或 视图 ) 下 进行 的 。 这 一 点 许多 读 
者 都 没有 意识 到 。 


7.4.4 路 由 优先 级 


通过 前 面 的 学 习 ， 我 们 已 经 知道 ， 不 同 路 由 协议 (包括 静态 路 由 
协议 和 各 种 动态 路 由 协议 ) 所 采用 的 路 由 算法 是 不 一 样 的 ， 如 RIP 协 议 
是 根据 路 径 传递 的 跳 数 来 决定 路 径 长 短 〈 也 就 是 传输 距离 ) 的 ， 而 
EIGRP 协 议 是 根据 路 径 传输 中 的 带宽 和 延迟 来 决定 路 径 开销 来 体现 传 
输 距离 的 ， 这 是 两 种 不 同 单位 的 度量 值 。 那 当 路 由 器 同时 配置 了 源 和 
目的 节点 (或 目的 网 络 ) 的 不 同类 型 路 由 时 ， 路 由 器 该 首选 采用 哪 条 
路 由 表 项 呢 ? 如 果 没 有 一 个 统一 的 度量 单位 ， 就 无 法 比较 了 ， 于 是 
Cisco 就 定义 了 一 种 称 为 “管理 距离 ”(Administrative Distance，AD) 的 
度量 单位 ， 也 是 表示 路 由 优先 级 的 度量 单位 。 


管理 距离 是 指 一 种 路 由 协议 的 路 由 可 信和 度 ， 有 是 一 个 0~255 之 间 的 一 
个 整数 ， 值 越 低 ， 优 移 级 越 高 ， 也 束 是 可 信和 度 越 高 。 每 一 种 路 由 协议 
按 可 靠 性 从 高 到 低 ， 依 次 分 配 一 个 管理 距离 ， 以 代表 对 应 类 型 路 由 的 
信任 等 级 。 这 样 我 们 束 可 以 统一 单位 ， 从 而 衡量 不 同 协议 的 路 径 开销 
以 选 出 最 优 路 径 。Cisco 设 备 中 对 不 同 协议 路 由 所 设 定 的 默认 管理 距离 
如 表 7-8 所 示 。 注 意 : 如 果 静 态 路 由 使 用 下 一 跳 所 对 应 的 接口 奉 代 下 一 
跳 IP 地 址 时 ， 则 目的 网 络 被 认为 是 直 连 网 络 ， 即 管理 距离 为 0 。 


表 7-8 Cisco 设备 不 同 协议 路 由 的 默认 管理 距离 


路 由 类 型 管理 距离 管理 距离 
EIGRP 汇总 路 由 RIP 120 
外 部 BGP EGP 140 
IGRP 100 200 


但 要 ， 不 同 设 备 广 商 对 路 由 优先 级 的 定义 并 不 完全 一 样 ， 如 华 
为 、H3C 对 不 同 协 议 路 由 所 设置 的 默认 优先 级 如 表 7-9 所 示 。 


表 7-9 华为 、H3C 设备 不 同 协 议 路 由 的 默认 优先 级 


路 由 类 型 管理 距离 管理 距离 
直 连 路 由 OSPF NSSA( 非 纯 末梢 区 域 ) 150 
Wi 


OSPF ASE( 自治 系统 外 部 ) 


以 上 仅 是 默认 的 优先 级 设置 ， 管 理 员 可 以 针对 每 条 路 由 修改 为 不 
同 于 默认 值 的 优先 级 值 。 通 过 对 到 达 同 一 目的 节点 (或 目的 网 络 ) 的 
多 条 相同 类 型 的 路 由 配置 不 同 的 优先 级 值 (在 静态 路 由 中 称 之 为 “浮动 
静态 路 由 ”) 就 可 以 达到 “ 热 备 切换 ?的 目的 。 就 是 当 优先 级 较 高 的 当前 
路 由 失效 时 ， 优 和 级 较 低 的 同一 目的 地 的 路 由 马上 可 以 接替 原来 路 由 
的 工作 ， 以 确保 到 达 某 一 目的 地 的 路 由 始终 有 效 。 


7.4.5 路 由 算法 设计 目标 和 设计 考虑 


路 由 算法 通常 具有 下 列 设计 日 标的 一 个 或 多 个 ， 即 正确 性 
(Correctness) 、 简单 性 (Simplicity) 、 健 壮 性 (Robustness) 、 稳 定 
性 (Stability) 、 公 平 性 (Fairness) 、 最 优 性 (Optimality) 和 灵活 有 
效 性 (Efficiency) 。 


(1) 正确 性 和 简单 性 


对 于 正确 性 和 简单 性 比较 好 理解 ， 束 旦 要 求 所 设计 的 路 由 算法 能 
正确 计算 出 网 络 中 的 最 优 路 径 ， 而 且 要 求 是 最 商 单 的 ， 太 复杂 的 会 三 
重 消耗 路 由 器 资源 。 换 句 话 说 ， 路 由 协议 必须 高 效 地 提供 其 路 由 功 
能 ， 尽 量 减少 软件 和 应 用 的 开锁。 当 实 现 路 由 算法 的 软件 必须 运行 在 
物理 资源 有 限 的 计算 机 上 时 高 效 尤 其 重要 。 


(2) 健壮 性 和 稳定 性 


健壮 性 和 稳定 性 融 是 要 求 路 由 算法 在 出 现 某 些 设备 工作 不 正 币 ， 
或 不 可 预见 的 软件 事件 的 情况 下 必须 仍 能 正常 处 理 ， 不 会 产生 大 的 网 
络 振荡 。 因 为 网 络 一 旦 投入 运行 ， 特 别 是 大 型 公共 服务 网 络 ， 会 要 求 
持续 、 有 效 运 行 数 年 ， 甚 至 更 人 。 在 此 期 间 ， 将 会 有 各 种 各 样 的 软 、 
硬件 问题 。 主 机 、 路 由 夯 和 线路 都 有 可 能 会 经 前 性 地 出 铺 ， 网 络 拓扑 
结构 也 可 能 会 多 次 发 生变 化 。 路 由 算法 应 能 够 很 好 地 适应 这 些 变 化 ， 


实现 快速 地 收敛 ， 而 且 不 会 要 求 所 有 主机 都 停止 工作 ， 即 使 在 某 台 路 
由 右 朋 满 时 。 


(3) 公平 性 和 最 优 性 


公平 性 是 要 求 路 由 算法 对 网 络 中 的 所 有 用 户 必 须 是 平等 的 。 最 优 
性 指 路 由 算法 选择 最 佳 路 径 的 能 力 ， 根 据 Metric 的 值 和 权 值 来 计算 。 例 
如 有 一 种 路 由 算法 可 能 使 用 跳 数 和 延迟 ， 但 延迟 的 权 值 可 能 要 大 些 。 
当然 ， 路 由 协议 必须 严格 定义 计算 Metric 的 算法 。 表 面 上 看 来 这 两 者 是 
有 些 冲 突 的 ， 但 事实 上 一 个 好 的 路 由 算法 必须 在 两 个 指标 之 间 选 择 一 


个 最 佳 的 平衡 点 。 


(4) 快速 收敛 性 


快速 收敛 性 是 指 路 由 算 法 必须 能 快速 案 合 ， 聚 合 是 所 有 路 由 絮 对 
最 佳 路 径 达成 一 致 的 过 程 。 当 某 网 络 事件 使 路 径 断 掉 或 不 可 用 时 ， 路 
由 器 通 过 网 络 分 发 路 由 更 新 信息 ， 促 使 最 佳 路 径 的 重新 计算 ， 最 终 使 
所 有 路 由 右 达 成 一 至。 聚合 很 慢 的 路 由 算法 可 能 会 产生 路 由 环 或 网 路 
中 断 。 


在 图 7-26 所 示 的 位 单 路 由 结构 中 ， 录 分 组 X 在 时 间 t1 内 到 达 路 由 紫 
1， 路 由 絮 1 已 经 更 新 ， 并 知道 到 达 目 的 的 最 佳 路 径 是 以 路 由 器 2 为 下 一 
跳 的 ， 于 十 束 把 该 分 组 转发 给 路 由 闫 2。 但 是 如 果 由 于 没有 快速 链 路 聚 
合 性 能 ， 路 由 右 2 则 可 能 还 没有 及 时 更 新 ， 它 仍 采 用 它 上 次 数据 发 送 的 


路 由 表 ， 认 为 它 的 最 佳 下 一 跳 是 路 由 器 1， 于 是 把 该 分 组 发 回 给 路 由 器 
1， 结 采 分 组 在 两 个 路 由 器 间 来 回 传递 ， 直 到 路 由 器 2 收 到 路 由 更 新 信 
轧 ， 或 分 组 超过 了 生存 期 。 


路 由 器 1 路 由 器 2 
到 路 由 器 X 的 数据 包 区- 和 
路 由 表 (Routing table) 路 由 表 (Routing table) 
Dest:X Send to :R2 Dest:X Send to :RI] 


图 7-26 路 由 右 不 能 快速 聚合 链 路 的 示例 


路 由 算法 还 应 该 是 灵活 有 效 的 ， 即 它们 应 该 迅速 、 准 确 地 适应 各 
种 网 络 环 境 。 例 如 ,假定 某 网 段 断 控 了 ， 当 知道 问题 后 ， 很 多 路 由 算 
法 对 通常 使 用 该 网 段 的 路 径 迅 速 选择 次 佳 的 路 径 。 路 由 算法 可 以 设计 
得 适应 网 络 市 完 、 路 由 紫 队 列 大 小 和 网 络 延迟 。 


在 设计 路 由 算法 时 ， 还 需要 考虑 许多 路 由 技术 元 素 ， 如 性 能 标 
准 、 成 本 、 决 策 时 间 、 决 策 地 点 、 网 络 信息 源 和 更 新 时 间 等 。 性 能 标 
准 方面 需要 考虑 跳 数 、 成 本 、 延 迟 、 天 吐 量 等 几 个 方面 。 成 本 与 数据 
率 有 关 (数据 率 越 高 ， 成 本 越 低 ) ， 成 本 也 与 当前 排队 延迟 有 关 。 可 
采取 最 小 跳 计数 标准 ， 或 者 最 小 成 本 标准 。 


在 决策 时 间 方 面 ， 对 于 内 部 数据 报 ， 需 要 为 每 个 包 单 独 做 路 由 决 
策 ， 对 于 内 部 虚 电 路 ， 只 需 在 建立 虚 电 路 时 做 路 由 决策 。 在 决策 地 点 
方面 ， 对 于 分 布 式 路 由 方式 ， 每 个 结 点 都 负责 为 到 达 的 包 选 择 一 条 输 
出 链 路 ， 故 需要 考虑 每 个 结 点 ， 对 于 集中 式 路 由 方式 ， 则 由 某 些 指定 
结 点 (如 网 络 控制 中 心 ) 负责 决策 ， 所 以 只 需 针 对 中 心 结 点 ， 对 于 源 
路 由 方式 ， 路 由 决策 实际 上 由 源 站 点 而 非 网 络 作 出 ， 所 以 只 需 针 对 原 


和 人 zy 十 
台 结 点 . 


在 网 络 信息 源 和 更 新 时 间 这 两 个 方面 ， 大 多 数 路 由 决策 要 求 根据 
网 络 拓扑 、 通 信和 负载 和 链 路 成 本 等 知识 做 出 决定 。 信 息 更 新 时 间 走 信 
思源 和 路 由 决 合 的 轴 数 。 如 条 像 扩散 算法 那样 是 无 信息 的 ， 也 了 吏 无 更 
新 之 说 了 ; 如果 信息 是 局 部 的 ， 则 更 新 基本 上 有 是 连续 的 ， 如 有 果 是 相 邻 
接 结 点 或 者 全 部 结 点 ， 则 在 采用 非 自 适应 算法 时 从 不 更 新 信息 ， 而 在 
采用 自 适 应 算法 时 经 常 更 新 信息 。 


7.5 儿 种 主要 的 路 由 算法 解析 


通过 前 面 的 学 习 我 们 知道 ， 路 由 算法 分 为 静态 路 由 算法 和 动态 路 
由 算法 两 大 类 。 其 中 静态 路 由 算法 包括 最 短路 径路 由 (Shortest Path 
Routing) 算法 、 扩 散 路 由 (Flooding Routing) 算法 和 基于 流量 的 路 由 
(Flow-Based Routing) 算法 。 动 态 路 由 算法 则 包括 距离 天 量 路 由 
(Distance Vector Routing) 算法 、 链 路 状态 路 由 (Link State Routing) 
算法 和 分 级 路 由 (Hierarchical Routing) 算法 等 。 本 节 仅 对 最 短路 径路 
由 、 扩 散 路 由 、 距 离 向 量 路 由 和 链 路 状态 路 由 这 四 种 算法 进行 介绍 。 


7.5.1 最 短路 人 径路 由 算法 


最 短路 人 径路 由 算法 古 一 种 从 源太 扩 一 段 段 地 同 目 的 太后 方向 查找 
到 达 源 节点 长 度 最 短 的 链 路 ， 以 此 来 确定 一 个 结 点 到 另 一 结 点 的 最 短 
路 径 。 它 的 基本 思想 是 构建 通信 子 网 拓扑 图 (不 包括 资源 子 网 部 
分 | ， 图 中 的 每 个 结 点 代表 一 个 路 由 器 ， 这 些 路 由 器 串 接 起 来 就 代表 
一 条 通信 线路 。 


最 典型 的 最 短路 径路 由 算法 就 是 Dijkstra 算 法 (迪克 斯 特 拉 算 
法 ) ， 是 由 Dijkstra 发 明 的 。 在 该 算法 中 ， 为 了 在 一 对 给 定 的 路 由 器 结 
点 之 间 选 择 一 条 最 短路 由 路 径 ， 只 需 在 通信 子 网 拓扑 图 中 找到 在 起 始 


和 结束 结 点 之 间 的 中 间 结 点 串 连 起 来 后 链 路 长 度 最 短 的 路 径 (这 里 指 
线路 长 度 ) 即 可 。 它 把 最 短路 由 的 结 点 标识 为 工作 结 点 ， 并 且 是 永久 
性 的 结 点 ， 其 到 达 源 下 点 的 距离 值 是 不 能 改变 的 ， 其 他 的 标识 为 临时 
性 的 结 点 ， 其 到 达 源 广 上 后 的 距离 可 能 会 随 工作 结 点 的 不 同 而 改变 。 所 
有 工作 结 点 串联 起 来 就 是 源 节 点 和 目的 节点 之 间 的 最 短路 由 路 径 ， 打 
个 比方 来 说 。 现 假设 我 们 要 从 A 城市 到 达 H 城 市 ， 如 图 7-27 所 示 。 目 先 
我 们 肯定 是 先 在 A 城市 找 一 条 与 目的 城市 H 同 方向 的 最 短 出 发 路 线 (从 
图 中 可 以 看 出 共有 三 条 路 可 选 ) ， 假 设 由 A 到 B 这 条 路 是 最 短 的 ， 所 以 
首 移 选 择 这 条 路 线 出 发 。 


图 7-27 “Dijkstra 算 法 ”比喻 示例 


当 我 们 到 达 B 地 点 后 ， 又 要 选择 一 条 可 以 到 达 目 的 城市 H 的 最 佳 路 
径 〈 共 有 2 条 路 线 可 选 ) ， 这 条 路 径 要 求 离 B 地 点 最 近 ， 假 设 选择 到 达 F 


地 点 这 条 。 然 后 在 F 地 继续 寻找 一 条 可 以 到 达 目 的 城市 H 的 最 短路 线 ， 
因为 F 地 点 有 条 路 直接 到 达 目 的 城市 H， 所 以 直接 选择 这 条 即 可 ， 基 终 
到 达 了 目的 城市 H。 


以 上 就 古 Dijkstra 最 短路 径 算 法 的 基本 思想 ， 下 面 通 过 一 个 具体 的 
网 络 路 由 示例 来 加 深 对 它 的 理解 。 


图 7-28 所 示 的 子 网 图 是 一 个 典型 的 最 短路 径路 由 算法 子 网 图 ， 图 中 
的 每 一 个 结 点 代表 一 台 路 由 器 ， 每 条 线段 代表 一 条 通信 链 路 。 现 假设 
要 使 用 Dijkstra 算 法 计算 结 点 A 到 结 点 D 之 间 的 最 短路 径 。 在 网 络 中 路 由 
器 启动 时 ， 首 先 需 要 初始 化 ， 测 量 每 条 链 路 的 长 度 ， 参 见 图 7-28 所 示 的 
各 条 线段 上 的 数字 。 
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图 7-28 典型 的 Dijkstra 算 法 子 网 图 


下 面 是 从 A 结 点 到 达 D 结 点 的 路 由 确定 步 又 。 


1) 首 移 将 源 结 点 A 标 记 为 永久 性 工作 结 点 〈 我 们 用 箭头 来 特别 标 
识 ) ， 然 后 依次 检查 每 一 个 与 A 结 点 直接 连接 的 相 邻 结 点 ， 并 且 把 它们 
与 A 结 点 之 间 的 距离 重新 以 tn，N) 的 方式 进行 标识 ， 其 中 的 n 为 与 A 
结 点 相距 的 链 路 长 度 ，N 为 最 近 的 工作 结 点 。 


因为 本 示例 中 与 结 点 A 直 接 相 邻 的 结 点 只 有 B 和 G， 上 所 以 仅 需 标 识 
这 两 个 结 点 与 A 结 点 之 间 的 距离 。 此 时 的 工作 结 点 为 A， 如 图 7-29 所 
示 ，B 结 点 的 标识 为 2，A) ，G 结 点 的 标识 为 (6，A) 。 之 所 以 这 样 
标注 ， 是 因为 B 结 点 到 A 结 点 的 链 路 长 度 为 2，G 结 点 到 A 结 点 的 链 路 长 
度 为 6。 其 他 与 A 结 点 不 相 邻 的 结 点 的 距离 标识 为 无 穷 远 。 


图 7-29 以 A 结 点 为 工作 绪 点 标记 其 他 相 邻 结 点 与 A 结 点 之 间 的 距离 


2) 比较 B 和 G 这 两 个 结 点 与 A 结 点 之 间距 离 ， 可 以 看 出 B 结 点 的 距 
离 更 短 ， 于 是 把 B 结 点 改 为 工作 结 点 (箭头 移 到 B) ， 同 时 将 其 变 为 永 
和 久 性 结 点 ， 其 他 结 点 (包括 G 结 点 ) 标注 为 临时 结 点 。 然 后 再 以 B 结 点 


为 工作 结 点 ， 标 记 直 接 相 邻 的 结 点 到 源 结 点 A 的 距离 ， 当 然 对 于 前 面 已 
经 计算 过 的 绪 点 将 略 过 ， 如 G 结 点 。 


本 示例 中 与 B 结 点 直接 相 邻 的 结 点 中 ， 除 了 A 结 点 外 还 有 C、E 这 两 
个 结 点 。C 结 点 到 达 A 结 点 的 距离 就 是 C 结 点 到 B 结 点 的 链 路 长 度 7 再 加 
上 B 结 点 到 A 结 点 的 链 路 长 度 2， 所 以 C 结 点 到 A 结 点 的 距离 为 2+7=9， 
故 将 其 标识 为 《9，B) 。 同 理 ，E 结 点 到 A 结 点 的 距离 为 2+2=4， 故 将 
其 标识 为 4，B) ， 如 图 7-30 所 示 。 其 他 既 不 与 A 结 点 又 不 与 B 结 点 相 
邻 的 结 点 距离 仍 为 无 穷 远 
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图 7-30 ”以 B 结 点 为 工作 结 点 标记 其 他 结 点 与 A 结 点 之 间 的 距离 


(6,A) 


3) 同样 经 过 比较 得 出 ，E 结 点 到 A 结 点 之 间 的 距离 (为 4) 比 C 结 
点 到 A 结 点 的 距离 (为 9) 近 ， 所 以 此 时 把 E 结 点 改 为 工作 结 点 〈 箭 头 移 
到 E) ， 同 时 标注 E 结 点 为 永久 性 结 点 ， 其 他 结 点 (包括 C 结 点 ) 标注 
为 临时 绪 点 。 


按 同样 方法 标注 与 E 结 点 直接 相 邻 的 结 点 (包括 结 点 B、 结 点 G 和 
结 点 F) 到 E 结 点 的 距离 ， 但 对 于 前 面 已 计算 过 的 永久 性 B 结 点 不 再 重新 
计算 ， 而 对 于 虽然 原来 已 计算 过 ， 但 为 临时 性 结 点 的 G 以 及 F 结 点 均 需 
要 重新 计算 。 最 终 G 结 点 的 标识 改 为 5，E) 《在 此 步 以 前 为 〈6， 

A) ) ，F 结 点 标识 为 (6，E) ， 表 示 G 结 点 和 F 结 点 到 达 A 结 点 的 距离 
分 别 为 5 和 6， 如 图 7-31 所 示 。 
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图 7-31 以 E 结 点 为 工作 结 点 标记 其 他 结 点 与 A 结 点 之 间 的 距离 


4) 再 用 同样 的 方法 比较 G 结 点 和 F 结 点 到 达 A 结 点 之 间 的 距离 ， 可 
以 得 出 G 结 点 更 近 ， 所 以 此 时 把 G 结 点 改 为 工作 结 点 《箭头 移 到 E) ， 
同时 标注 G 结 点 为 永久 性 结 点 ， 其 他 结 点 〈 包 括 F 结 点 ) 标注 为 临时 结 
点 ， 如 图 7-32 所 示 。 
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图 7-32 以 G 结 点 为 工作 结 点 标记 其 他 结 点 与 A 结 点 之 间 的 距离 


再 看 一 下 与 G 结 点 直接 相 邻 的 结 点 ， 包 括 A、E、H 这 三 个 结 点 , 但 
是 A、E 这 两 个 结 点 在 前 面 都 已 标识 为 永久 性 结 点 了 ， 标 识 是 不 能 更 改 
的 ， 所 以 在 这 里 只 需 对 H 结 点 计算 到 达 A 结 点 的 距离 了 。 经 过 计算 得 出 
为 (9, G) 。 


在 这 里 就 要 出 现 问 题 了 ， 按 照 上 面 的 计算 ， 此 时 应 该 把 H 结 点 标识 
为 下 一 个 工作 结 点 ， 但 事实 上 ， 由 H 结 点 经 G 结 点 到 达 E 结 点 的 距离 
(4+1=5) 要 长 于 由 H 结 点 经 F 结 点 到 达 E 结 点 的 距离 (2+2=4) ， 所 以 
经 过 后 面 的 计算 发 现 ， 在 前 面 把 G 结 点 标识 为 永久 结 点 是 错误 的 ， 这 时 
要 把 F 结 点 标识 为 工作 结 点 〈 箭 头 移 到 F) ， 撤 销 G 结 点 永久 工作 结 点 的 
资格 ， 如 图 7-33 所 示 。 
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图 7-33 以 F 结 点 为 工作 结 点 标记 其 他 结 点 与 A 结 点 之 间 的 距离 


5) 再 检查 与 F 结 点 相 接 相连 接 的 相 邻 结 点 ， 除 了 原来 已 标识 为 永 
久 性 结 点 的 E 外 ， 其 余 就 是 C 和 H 这 两 个 临时 结 点 了 。 重 新 计算 它们 到 
结 点 A 间 的 距离 ， 得 到 的 值 分 别 为 和 8。 这 里 还 要 注意 一 个 现象 ， 就 是 
对 于 C 结 点 ， 本 来 属于 临时 结 点 ， 需 要 重新 计算 距离 值 ， 可 是 经 过 F 结 
点 到 A 结 点 的 距离 与 原来 计算 所 得 的 经 过 B 结 点 到 达 A 结 点 的 距离 是 一 
样 的 ， 所 以 距离 值 不 需要 改变 。 此 时 把 距离 较 短 的 H 结 点 标识 为 工作 结 
点 (箭头 移 到 H) 和 永久 性 结 点 ， 如 图 7-34 所 示 。 


图 7-34 以 H 结 点 为 工作 结 点 标记 其 他 结 点 与 A 结 点 之 间 的 距离 


此 时 ， 因 为 H 结 点 是 直接 与 目的 结 点 D 相 连 ， 所 以 无 需 再 进行 选举 
了 ， 直 接 标识 D 结 点 的 距离 为 (10，H) 。 即 从 源 结 点 A 到 目标 结 点 D 
的 最 短 距离 就 为 10， 即 2+2+2+2+2， 如 图 7-34 所 示 的 连 线 : 
A-B-E-F-H-D。 这 样 ， 找 出 了 源 结 点 到 目的 结 点 的 最 短 距离 
了 o 


从 以 上 可 以 看 出 ，Dijkstra 算 法 虽然 能 得 出 最 短路 径 ， 但 由 于 它 壳 
历 计算 的 结 点 很 多 ， 所 以 效率 低 。 另 外 ， 有 些 结 点 还 不 能 一 次 标识 正 
确 ， 因 为 还 要 考虑 后 续 结 点 到 达 源 结 点 的 距离 ， 如 以 上 示例 中 G 结 点 和 
F 结 扩 的 工作 结 点 标识 ， 最 初 的 标识 束 是 错误 的 ， 因 为 它 没 有 考虑 后 续 
结 点 到 源 结 点 的 距离 。 


7.5.2 ”扩散 算法 


扩散 (Flooding) 算法 也 是 一 种 静态 路 由 算法 。 最 初 原始 的 扩散 
方法 是 ， 每 一 个 接收 到 的 分 组 都 被 从 除 接收 端口 之 外 的 所 有 其 他 端口 
上 转发 出 去 。 图 7-35 所 示 的 是 数据 分 组 在 源 结 点 1 上 分 散 到 了 三 个 链 
路 。 


的 
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7-35” 结 点 1 分 散 成 三 个 线路 发 送 数 据 包 


很 显然 ， 原始 的 扩散 算法 会 产生 大 量 的 分 组 副本 ， 如 在 图 7-36 
中 ， 当 数据 分 组 到 了 结 点 2 和 结 点 3 后 都 会 向 所 有 可 能 的 链 路 上 发 送 分 
组 ， 这 样 就 会 出 现 分 组 重复 。 而 且 越 后 面 的 结 点 收 到 的 重复 数据 分 组 
越 多 。 如 3 号 结 点 ， 它 既 有 直接 从 结 点 1 发 来 的 分 组 ， 又 有 经 过 2 号 结 点 
转发 的 同一 分 组 ， 还 有 从 4 号 结 点 发 来 的 同一 分 组 。 不 仅 如 此 ， 这 种 扩 
散 法 还 会 造成 分 组 死 循 环 ， 如 3 号 结 点 发 来 的 分 组 ， 它 又 会 同 2 号 结 点 


返回 一 样 的 分 组 。 这 样 ， 即 使 是 真正 的 目的 节点 ， 也 可 能 会 接收 到 多 
个 同样 的 分 组 ， 这 显然 是 没有 任何 意义 。 
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7-36” 结 点 2 和 结 点 3 同 所 有 出 镜 线 路 发 送 数 据 包 


为 了 解决 以 上 各 端口 会 重复 接收 相同 分 组 的 问题 ， 设 计 痢 又 想 出 
了 两 种 办 法 。 其 中 一 种 办 法 是 在 每 个 分 组 头 部 中 携 市 一 个 跳 数 计数 
絮 ， 分 组 每 到 一 个 结 点 其 跳 数 计数 右 束 减 1， 当 计数 絮 减 到 0 时 则 该 分 
组 将 被 丢 弃 。 而 计数 器 的 初始 值 可 以 设 为 通信 子 网 的 直径 ， 即 相距 最 
远 的 两 个 结 点 之 间 的 跳 数 ， 这 样 可 以 减少 那些 循环 转发 的 分 组 。 


另 一 种 办 法 是 在 结 点 上 记 住 哪些 分 组 已 经 转发 过 了 ， 对 于 重复 接 
收 的 分 组 直接 丢弃 ， 从 而 确保 一 个 分 组 不 会 被 同一 个 结 点 转发 两 次 。 
这 要 求 源 结 点 从 主机 收 到 一 个 分 组 后 ， 为 分 组 分 配 一 个 序号 ， 同 一 分 
组 的 序号 相同 ， 殉 像 我 们 在 前 面 介绍 数据 帧 的 发 送 时 为 每 个 帧 分 配 一 
个 序号 一 样 ， 重 发 的 同一 数据 帧 序号 一 样 ， 这 样 接 收 端 殉 可 以 确保 对 
于 同一 个 帧 只 接收 一 次 。 同 时 每 一 个 结 点 对 于 每 一 个 源 结 点 都 要 维护 


张 序 号 表 ， 记 录 收 到 的 来 目 同一 源 结 点 的 所 有 分 组 序号 。 每 当 一 个 
结 点 收 到 来 目 某 个 源 结 点 的 分 组 时 ， 束 用 分 组 的 序号 去 查找 该 源 结 点 
的 序号 表 ， 如 果 该 序号 已 在 表 中 则 该 分 组 被 丢弃 。 为 了 防止 序号 表 过 
大 ， 序 号 表 中 还 应 增设 一 个 计数 器 k， 表 示 序 号 直至 k 的 分 组 都 已 经 转 
发 过 了 ， 从 而 不 需要 保留 序号 小 于 k 的 序号 。 


尽管 扩散 路 由 算法 有 它 的 不 足 ， 但 也 不 是 说 它 一 无 用 处 。 由 于 它 
的 数据 分 组 的 分 散 传 送 ， 使 它 的 健壮 性 非常 好 ， 在 一 些 经 常 遭 到 破坏 
的 网 络 系统 中 是 非常 需要 的 。 如 军事 网 络 系统 ， 可 能 在 战争 中 被 瞬间 
炸 得 粉碎 ， 但 由 于 路 由 右 间 采取 了 扩散 路 由 算法 ， 这 样 在 系统 中 只 
存在 一 个 链 路 ， 数 据 仍 能 完整 地 向 前 传输 。 男 外 ， 在 无 线 网 络 中 ， 一 
个 站 点 发 出 的 所 有 消 轧 可 以 被 位 于 无 限 距离 范围 内 的 所 有 站 接收 ， 这 
实际 上 也 十 一 种 扩散 算法 。 还 有 融 是 在 数据 库 系统 中 ， 如 果 数 据 库 系 
统 中 有 多 台 服 务 器 ， 采 取 扩 散 算 法 ， 则 数据 库 系 统 的 更 新 效率 会 大 大 


提高 。 


7.5.3 ”距离 天 量 路 由 算法 


现代 计算 机 网 络 通 利 使 用 动态 路 由 算法 ， 因 为 这 类 算法 能 够 适应 
网 络 的 拓扑 和 流量 变化 ， 其 中 最 流行 的 两 种 动态 路 由 算法 钙 距 离 和 天 量 
路 由 算法 和 链 路 状态 路 由 算法 。 


距离 矢量 路 由 算法 (Distance Vector Routing，DV) 是 ARPANET 网 
络 上 最 早 使 用 的 路 由 算法 ， 又 称 Bellman-Ford 路 由 算法 和 Ford-Fulkerson 
算法 ， 主 要 在 RIP (Route Information Protocol) 协议 中 使 用 。Cisco 的 
IGRP 和 EIGRP 路 由 协议 也 是 采用 DV 这 种 路 由 算法 的 。 


距离 天 量 路 由 算法 的 基本 思想 如 下 : 每 个 路 由 器 维护 一 个 距离 天 
量 (通常 是 以 延 时 十 作 变 量 的 ) 表 ， 然 后 通过 相 邻 路 由 器 之 间 的 距离 
矢量 通告 进行 距离 矢量 表 的 更 新 。 每 个 距离 矢量 表 项 包括 两 部 分 ， 到 
达 目 的 节点 的 最 佳 输 出 线路 ， 和 到 达 目 的 市 点 所 需 时 间或 距离 ， 通 信 
子 网 中 的 其 他 每 个 路 由 器 在 表 中 占据 一 个 表 项 ， 并 作为 该 表 项 的 索 
引 。 每 隔 一 段 时 间 ， 路 由 融会 同 所 有 邻居 结 点 发 送 它 到 每 个 目的 斑点 
的 距离 表 ， 同 时 它 也 接收 每 个 邻 届 结 点 发 来 的 距离 矢量 表 。 这 样 以 此 
类 推 ， 经 过 一 段 时 间 后 便 可 将 网 络 中 各 路 由 右 所 获得 的 距离 矢量 信息 
在 各 路 由 器 上 统一 起 来 ， 这 样 各 路 由 右 只 需要 查看 这 个 距离 矢量 表 就 
可 以 为 不 同 来 源 分 组 找到 一 条 最 佳 的 路 由 。 


现 假定 用 延 时 作为 距离 的 度量 ， 举 一 个 简单 的 例子 ， 如 图 7-37 所 
示 。 假 设 某 个 时 候 路 由 器 Y 收 到 其 邻居 路 由 器 X 的 距离 天 量 ， 其 中 m 是 
Y 售 计 到 达 路 由 屁 X 的 延 时 。 邦 Y 路 由 絮 知 道 它 到 邻居 Z 的 延 时 为 n， 那 
么 它 可 以 得 知 2 通过 Y 到 达 X 需 要 花费 时 间 m+n。 如 果 Z 路 由 做 还 有 其 他 
相 邻 路 由 器 ， 则 对 于 从 其 他 邻居 那里 收 到 的 距离 矢量 ， 该 路 由 器 执行 
同样 的 计算 ， 最 后 从 中 选择 费时 最 少 的 路 由 作为 Z 去 往 X 的 最 住 路 由 ， 
然后 更 新 其 路 由 表 ， 并 通告 给 其 邻居 路 由 器 。 


| m | n . 
\ 


图 7-37 距离 矢量 路 由 算法 简单 实例 


现 通 过 图 7-38 所 示 的 示例 介绍 距离 天 量 算 法 中 的 路 由 的 确定 流程 ， 
各 段 链 路 的 延 时 均 已 在 图 中 标注 * A、B、C、D、E 代 表 五 个 路 由 器 ， 
假设 路 由 表 的 传递 方向 为 : AB 一 C-D-E (这 与 路 由 器 启动 的 先后 
次 序 有 关 ) 。 下 面 介绍 具体 的 流程 。 


图 7-38 距离 矢量 算法 路 由 确定 示例 


1) 初始 状态 下 ， 各 路 由 器 都 只 收集 直接 相连 的 链 路 的 延 时 信息 ， 
各 路 由 融 结 点 得 出 各 目的 初始 天 量 表 如 图 7-39 所 示 。 因 为 各 结 点 间 还 没 
有 交换 路 由 信息 ， 所 以 它们 的 初始 状态 的 路 由 表 同 它们 的 矢量 表 一 
样 。 


图 7-39 初始 状态 下 各 结 扩 的 矢量 表 


2) 现在 路 由 器 A 把 它 的 路 由 表 发 给 路 由 器 B。 此 时 路 由 B 会 综合 从 
A 路 由 器 发 来 的 路 由 表 和 自己 的 初始 路 由 表 ， 更 新 出 一 个 新 的 天 量 表 ， 
如 图 7-40a 所 示 〈 最 终 的 天 量 表 如 图 中 深 颜 色 部 分 | 。 从 图 中 可 以 看 
出 ， 从 B 绪 点 到 达 E 结 点 存在 两 条 路 径 ， 一 条 是 直达 的 ， 一 条 是 通过 A 
结 点 到 达 的 。 而 且 这 两 条 线 的 开销 不 同 ， 经 过 A 结 点 到 达 E 结 点 的 开销 


(7) 比 直达 线路 的 开销 (8) 更 低 ， 所 以 最 终 在 形成 的 路 由 表 中 ， 把 
到 达 E 结 点 的 线路 改 为 经 A 结 点 这 条 线路 ， 如 图 7-40b 所 示 。 


b) 路 由 表 


图 7-40 B 结 点 新 的 矢量 表 和 路 由 表 


3) 路 由 器 B 再 把 最 终 形成 的 路 由 表 发 给 路 由 器 C。 同 样 ， 路 由 器 C 
也 要 把 自己 原来 的 初始 路 由 表 与 从 B 路 由 器 发 来 的 路 由 表 进 行 综合 ， 形 
成 新 的 矢量 表 ， 如 图 7-41a 所 示 《最 终 的 矢量 表 如 图 中 深 颜色 部 分 ) 。 
在 新 的 矢量 表 中 ， 除 了 最 初 的 直接 连接 的 B 和 D 结 点 间 的 矢量 外 ， 还 新 
收集 了 到 达 A 和 E 结 点 间 的 矢量 信息 。 因 为 C 结 点 没有 与 A 和 E 结 点 间 的 
直接 连接 ， 在 初始 路 由 表 中 并 没有 到 达 这 两 个 结 点 的 路 由 信息 ， 所 以 
现在 只 有 采用 从 B 路 由 亏 发 来 的 路 由 表 ， 经 过 B 结 点 到 达 A、E 结 点 。 


这 里 要 注意 一 点 ， 因 为 在 B 结 点 路 由 表 中 已 识别 了 直接 通过 B 结 点 
到 达 E 结 点 的 开销 (8) 还 比 依次 通过 B、A 结 点 到 达 E 结 点 的 开销 (7) 
大 ， 所 以 在 C 结 点 路 由 表 中 是 采用 依次 通过 B、A 结 总 到 达 E 结 点 这 条 路 
径 。 最 终 形成 的 路 由 表 如 图 7-41 上 图 所 示 。 


目的 节点 经 由 结 点 矢量 开销 


Tr 妈 肌 结 上 


b) 路 由 表 


图 7-41 C 结 点 新 的 矢量 表 和 路 由 表 


4) 路 由 器 C 再 把 它 的 最 终 路 由 表 发 给 路 由 器 D。 同 样 ， 路 由 器 D 也 
要 把 它 原来 的 初始 路 由 表 与 从 C 路 由 器 发 来 的 路 由 表 进 行 综合 ， 形 成 新 
的 矢量 表 ， 如 图 7-42a 所 示 (最 终 的 矢量 表 如 图 中 深 颇 色 部 分 )  。 在 新 
的 矢量 表 中 ， 除 了 最 初 的 直接 连接 的 C 和 E 结 点 间 的 矢量 信息 外 ， 还 新 
收集 了 到 达 A 和 B 结 点 的 天 量 信 息 。 因 为 D 结 点 没有 与 A 和 B 结 点 的 直接 
连接 ， 所 以 在 其 最 初 的 路 由 表 中 并 没有 到 达 这 两 个 结 点 的 矢量 信息 ， 
此 时 仍 采 用 经 过 C 结 点 到 达 A 和 B 结 点 的 路 径 。 


在 这 里 同样 要 注意 一 点 ， 从 D 结 点 到 达 E 结 点 也 有 两 条 路 径 : 一 是 
直接 到 达 ， 二 是 依次 通过 C、B、A 结 点 到 达 ， 经 过 比较 发 现 直接 连接 
到 达 的 开销 (2) 要 比 通过 C、B、A 结 点 到 达 E 结 点 路 径 的 开销 (10) 
要 小 ， 所 以 在 D 结 点 中 ， 到 达 E 结 点 采用 直接 连接 这 条 线路 。 最 终 形成 
的 路 由 表 如 图 7-42b 所 示 。 


经 由 结 点 矢量 开销 


b) 路 由 表 


图 7-42 D 结 点 新 的 矢量 表 和 路 由 表 


5) 路 由 器 D 再 把 它 的 最 终 路 由 表 发 给 路 由 器 E。 同 样 ， 路 由 絮 E 也 
要 把 它 原 来 的 初始 路 由 表 与 从 D 路 由 器 发 来 的 路 由 表 进 行 综合 ， 形 成 新 
的 矢量 表 ， 如 图 7-43a 所 示 (最 终 的 矢量 表 如 图 中 深 颇 色 部 分 ) 。 在 新 
的 矢量 表 中 ， 除 了 最 初 的 直接 连接 的 A、B 和 D 结 点 间 的 矢量 外 ， 还 新 
收集 了 a 到达 C 结 点 的 矢量 信息 ， 因 为 E 结 点 没有 与 C 结 点 的 直接 连接 。 
此 时 仍 采 用 经 过 D 结 点 到 达 C 结 点 的 路 径 。 


在 这 里 有 两 个 要 注意 的 地 方 ， 一 是 从 E 结 点 到 达 A 结 点 的 路 径 问 
题 ， 因 为 此 时 E 结 点 与 A 结 点 是 直接 连接 的 ， 而 且 其 开销 (1) 要 比 原来 
从 D 路 由 器 发 来 的 路 由 表 中 提供 的 通过 D、C、B 结 点 到 达 A 结 点 路 径 开 
销 (11) 要 小 ， 所 以 在 最 终 的 E 结 点 路 由 表 中 ， 到 达 A 结 点 采用 直接 连 
接 这 条 线路 。 二 是 E 结 点 虽然 也 与 B 结 点 直接 连接 ， 但 它 的 开销 (8) 还 
要 比 原来 从 D 路 由 天 发 来 的 路 由 表 中 提供 的 依次 经 过 D、C 这 两 个 结 点 
到 达 B 结 点 的 开销 (5) 大 ， 所 以 在 最 终 的 E 结 点 路 由 表 中 ， 到 达 B 结 点 


采用 依次 经 过 D、C 两 个 结 点 这 条 路 径 。 最 终 形 成 的 路 由 表 如 图 7-43b 所 


a) 矢量 表 b) 路 由 表 


图 7-43 下 结 点 新 的 矢量 表 和 路 由 表 


通过 以 上 步 又， 网 络 中 各 路 由 万 束 完 成 了 整个 路 由 表 的 确定 ， 当 
然 在 拓扑 结构 发 生变 化 时 ， 各 路 由 器 的 路 由 表 义 会 发 生变 化 ， 需 要 重 
新 进行 更 新 。 


7.5.4” 链 路 状态 路 由 算法 


上 市 介绍 的 距离 矢量 路 由 算法 比较 简单 ， 这 是 它 在 早期 网 络 几 平 
无 规模 可 言 时 能 得 到 广泛 应 用 的 主要 原因 。 在 网 络 拓扑 结构 相对 简单 
且 链 路 极 少 发 生 故 障 时 ， 这 种 算法 的 效果 完全 可 以 令 人 满意 ; 然而 ， 
对 于 庞大 而 复杂 的 网 络 ， 该 算法 计算 新 路 由 的 收敛 速度 极 慢 ， 而 且 在 
它 进 行 计算 过 程 中 ， 网 络 处 于 一 种 过 渡 状 态 ， 极 可 能 发 生 循 环 并 造成 
暂时 的 拥塞 。 再 者 ， 当 前 网 络 的 层 链 路 技术 多 种 多 样 ， 币 宽 各 不 相 
同 ， 而 距离 矢量 算法 对 此 则 视而不见 。 链 路 状态 路 由 算法 整 是 为 了 殉 
服 这 些 缺 点 才 提 出 并 发 展 起 来 的 。 代 表 协 议 如 OSPF、IS-IS 等 。 


链 路 状态 路 由 (Link State Routing) 算法 的 基本 思想 是 : 网络 中 各 
个 结 点 不 必 交 换 通 往 目 的 站 点 的 距离 ， 而 是 维护 一 张 网 络 拓扑 图 ， 在 
网 络 拓扑 结构 发 生变 化 时 及 时 更 新 拓扑 图 即 可 。 隐藏 在 链 路 状态 路 由 
算法 之 后 的 思想 十 分 简明 ， 它 由 以 下 五 个 步 又 组 成 。 


发 现 邻 居 结 点 ， 并 知道 其 网 络 地 址 ; 


上 一 
~ 


测量 到 各 邻居 结 扣 的 延 时 或 开销 ; 


[BS) 
A 


组 冯 一 个 分 组 ， 告 之 刚 知道 的 所 有 信息 


CD 
ep 


4) 将 这 个 分 组 发 送 给 所 有 其 他 路 由 器 ; 


5) 使 用 Dijkstra 算 法 (也 就 是 “最 短路 径 ” 算 法 计算 到 每 个 其 他 路 
由 咒 的 最 短路 径 。 


实际 上 ， 运 行 链 路 状态 算法 并 非 一 定 要 采用 Dijkstra 算 法 ， 唯 一 必 
须 遵从 的 要 求 是 所 有 结 点 都 应 该 使 用 完全 相同 的 度量 制式 ， 也 就 是 
说 ,不论 使 用 什么 算法 ， 只 要 能 找 出 相同 的 最 短路 径 丈 行 。 下 面 简单 
介绍 以 上 五 个 步 又 。 


1. 发 现 邻居 


当 一 个 路 由 髓 局 动 时 ， 它 的 第 一 个 任务 束 古 找 出 哪些 路 由 紫 是 它 
的 邻居 。 为 了 实现 这 个 目标 ， 它 只 需要 在 每 一 条 点 到 点 线路 上 发 送 一 
个 特殊 的 Hello 分 组 即 可 。 线 路 的 另 一 闯 的 路 由 天 应 发 送 一 个 应 答 来 说 
明 它 是 谁 ， 束 像 我 们 打 电 话 一 样 ， 当 一 方 发 出 问候 时 ， 对 方 会 做 出 回 
儿 ， 以 证 明 对 方 天 是 打 电 话 一 方 要 找 的 人 。 路 由 天 的 这 些 名 字 必 须 二 
全 局 唯一 的 。 


图 7-44 所 示 的 瓯 是 一 个 由 A 结 点 回 其 邻 届 结 点 发 送 Hello 请 求 分 组 
H_Re， 然 后 邻居 结 点 在 收 到 其 Hello 分 组 后 发 回 Hello 应 答 分 组 H_Rp 的 


和 
示意 图 。 


图 7-44 发 送 Hello 请 求 分 组 和 返回 Hello 应 答 分 组 的 示意 图 


2. 测 量 线路 延 时 


测量 线路 延 时 的 最 直接 方法 是 路 由 器 在 线路 上 发 送 一 个 特殊 的 
ECHO 分 组 ， 收 到 ECHO 分 组 的 路 由 器 必须 立即 发 回 一 个 应 答 ， 通 过 测 
量 发 送 与 接收 之 间 的 时 间 (来 回 时 间 ) 并 除 以 2， 可 以 得 到 单 向 的 线路 
延 时 。 可 以 多 测 几 组 数据 ， 求 平均 线路 延 时 ， 然 后 就 可 以 得 知 各 段 链 
路 之 间 的 延 时 ， 也 即 开销 (Cost) ， 如 图 7-45 所 示 。 


图 7-45 计算 链 路 开销 示意 图 


显然 以 上 我 们 假设 的 延 时 是 对 称 的 ， 也 就 是 分 组 发 送 和 返回 的 时 
间 是 一 样 的 ， 但 实际 上 往往 并 不 总 是 这 样 。 在 计算 线路 延 时 时 要 不 要 
考虑 线路 上 的 负载 ， 这 是 一 个 沽 有 争议 的 问题 。 如 果 考 虑 线路 上 的 负 
载 ， 那 么 发 送 时 间 应 从 ECHO 分 组 放 入 队列 时 算 起 ;如 果 不 考虑 线路 人 负 
载 ， 那 么 发 送 时 间 应 从 ECHO 分 组 到 达 队 头 时 算 起 。 考 虑 线路 负载 意味 
痢 当 两 条 线路 的 市 席 相 同时 ， 路 由 天 将 选择 负载 较 轻 的 线路 作为 最 佳 
输出 线路 ， 这 种 选择 能 导致 民 好 的 性 能 。 但 这 会 使 轻 负 载 的 线路 很 快 
超载 ， 从 而 导致 男 一 条 线路 又 成 为 最 住 选择 ， 这 样 容易 引起 路 由 表 的 
剧烈 振荡 ， 导 致 不 稳定 路 由 和 其 他 潜在 问题 的 产生 。 只 考虑 市 宽 不 考 


虑 负载 吏 不 会 出 现 这 种 问题 ， 但 完全 不 考虑 负载 也 是 不 合理 的 ， 因 为 
开会 使 流量 都 集中 到 高 市 宽 的 线路 上 ， 而 低 带 宽 的 线路 却 很 空间 。 


以 上 问题 的 根源 在 于 路 由 絮 尽 古 克 择 最 住 线 路 转发 分 组 ， 这 很 容 
易 引 起 负载 不 均衡 ， 因 此 较 明 智 的 做 法 和 是 将 负载 按 一 定 比 例 分 布 到 多 
条 线路 上 。 


3. 构 造 链 路 状态 分 组 


一 旦 收集 到 了 各 个 邻居 结 点 的 地 址 及 到 各 个 邻居 的 线路 延 时 之 
后 ， 束 可 以 构造 一 个 链 路 状态 分 组 来 携 市 这 些 信息 。 在 分 组 格式 中 ， 
首先 是 发 送 方 地 址 ， 然 后 是 分 组 序号 和 时 间 (也 即 链 路 状态 生存 时 
间 ，TTL) ， 最 后 是 一 个 邻居 列表 ， 每 个 表 项 包括 一 个 邻居 结 点 和 到 达 
这 个 邻居 结 扣 的 总 延 时 ， 如 图 7-46 所 示 。 


路 径 1 ， 路 径 2 路 径 3 | 路径 4 ， 路 径 5 ， 
路 由 器 A :到 - 
路 由 器 B A 国 
路 由 器 C A 
路 由 器 D A 
路 由 器 EE 时 间 大 w 
路 由 器 F | 序号 | 时 间 著 e 


图 7-46 链 路 状态 分 组 示例 


什么 时 候 构 造 链 路 状态 分 组 比较 合适 呢 ? 一 种 办 法 是 周期 性 地 产 
生 链 路 状态 分 组 ， 男 一 种 办 法 是 仅 在 发 现 网 络 拓 扑 发 生 改 变 时 才 产 
生 ， 如 邻居 集合 发 生 了 变化 ， 或 到 邻居 的 线路 延 时 发 生 了 变化 。 


4. 发 送 链 路 状态 分 组 


该 算法 最 复杂 的 部 分 是 如 何 可 靠 地 发 送 链 路 状态 分 组 。 当 分 组 被 
发 送 和 安装 后 ， 首 先 得 到 分 组 的 路 由 器 就 会 用 它 来 改变 自己 的 路 由 
表 ， 此 时 不 同 的 路 由 邦 可 能 会 使 用 不 同 的 网 络 拓扑 版 本 ， 这 可 能 导致 
不 一 致 、 路 由 环 路 、 不 可 到 达 结 点 和 其 他 问题 。 


为 了 可 靠 地 发 送 链 路 状态 分 组 ， 可 采用 扩散 算法 (这 在 前 面 已 有 
介绍 ， 参 见 7.5.2 刘 ) 。 每 个 分 组 携带 一 个 序号 ， 每 当 发 送 一 个 新 的 分 
组 时 ， 分 组 序号 就 加 1。 每 个 路 由 器 维护 一 张 由 源 路 由 器 、 分 组 序号 组 
成 的 列表 ， 记 录 从 每 个 源 路 由 咒 收 到 的 最 新 的 分 组 序号 。 当 一 个 链 路 
状态 分 组 到 来 时 ， 用 分 组 中 的 源 路 由 絮 地 址 和 序号 查 表 ， 如 采 这 是 
个 者 的 链 路 状态 分 组 ， 就 用 扩散 算法 再 将 其 转发 出 去 ， 否 则 将 分 组 丢 
弃 。 采 用 序号 来 区 分 新 旧 分 组 会 有 一 些 问 题 ， 一 是 当 序号 折 回 (因为 
序号 也 是 有 限制 的 ， 毕 竟 序 号 所 占 的 比特 位 是 限定 的 ) 时 ， 新 的 分 组 
都 会 被 丢 挥 ， 因 为 它们 与 原来 接收 的 分 组 号 ; 二 是 当 路 由 器 发 生 有 崩溃 
并 重 局 后 ， 只 能 从 序号 0 开始 发 送 ， 这 些 分 组 也 会 被 丢弃 ， 三 是 当 序 号 


在 传输 过 程 中 出 错时 ， 如 4 变 成 了 65540， 则 其 后 大 量 的 分 组 都 会 被 丢 
挥 ， 因 为 此 时 路 由 右 认 为 对 应 源 路 由 器 上 一 个 最 近 的 分 组 号 束 古 
65540， 后 面 的 分 组 号 必须 大 于 这 个 值 ， 人 否则 整 认为 古 重复 接收 的 。 


为 解决 序号 折 回 的 问题 ， 使 用 了 32 位 长 的 序号 ， 这 样 即 使 每 隔 一 
秒 发 送 一 个 链 路 状态 分 组 ， 也 需要 137 年 的 时 间 才 会 发 生 序号 折 回 ， 世 
束 彻 慌 解 决 了 折 回 问题 。 至 于 后 两 个 问题 ， 解 决 的 办 法 是 在 分 组 中 增 
加 一 个 寿命 域 ， 不 管 分 组 在 网 络 中 的 什么 地 方 ， 其 奉命 均 每 阳 一 秒 减 
1， 当 奉命 减 为 0 时 分 组 被 丢弃 。 这 种 廊 法 显然 很 验 。 


还 有 一 些 改进 的 措施 可 增加 算法 的 健壮 性 。 当 一 个 链 路 状态 分 组 
进入 一 个 路 由 器 并 需要 扩散 时 ， 该 分 组 并 不 马上 放 到 传输 队列 里 ， 而 
苹 放 到 一 个 临时 区 域 中 等 待 一 小 段 时 间 。 如 来 在 该 分 组 被 发 送 前 ， 来 
目 同一 个 源 路 由 器 的 另 一 个 链 路 状态 分 组 到 来 ， 则 将 这 两 个 分 组 的 序 
号 进行 比较 。 如 果 序 号 相同 ， 就 丢弃 后 来 的 分 组 ， 如 果 序号 不 同 ， 则 
序号 小 的 分 组 被 丢弃 。 


为 防止 分 组 在 路 由 此 到 路 由 此 的 传输 线路 上 出 错 ， 所 有 链 路 状态 
分 组 都 必须 被 确认 。 当 线路 空 采 时 ，I 临 时 区 域 梓 循环 扫 扩 ， 从 中 选择 
一 个 分 组 或 确认 进行 发 送 。 路 由 器 将 收 到 的 链 路 状态 分 组 存放 在 分 组 
缓冲 右 中 。 每 一 行 对 应 一 个 最 近 收 到 的 但 还 未 处 理 完毕 的 链 路 状态 分 
组 ， 除 记录 该 分 组 的 源 路 由 器 、 序 号 、 生 存 时间 、 数 据 以 外 ， 对 应 每 


一 条 输出 线路 还 有 发 送 和 确认 两 个 标志 位 ， 用 来 指示 是否 要 在 这 条 线 
路 上 转发 或 确认 这 个 分 组 。 


5. 计 算 新 路 由 


一 旦 一 个 路 由 器 收集 齐 了 一 整套 链 路 状态 分 组 ， 它 就 可 以 建立 完 
整 的 通信 子 网 图 。 在 这 张 图 中 每 条 链 路 均 被 报告 了 两 次 (因为 一 条 链 
路 连接 了 两 个 结 点 ， 它 们 会 分 别 进行 计算 ) ， 这 两 个 值 可 以 分 开 用 ， 
也 可 以 求 平均 值 。 图 建立 起 来 后 ， 束 可 以 运用 Dijkstra 算 法 求 路 由 器 到 
任何 目的 路 由 器 的 最 短 通路 了 。 图 7-47 所 示 的 就 是 图 7-44 所 示 网 络 的 最 
终 路 由 表 (各 路 由 右上 一 样 ) 。 


7-47 ”最终 的 链 路 状态 路 由 表示 例 


7.6 ”网 络 拥塞 控制 方法 和 原理 


网 络 拥塞 现象 是 指 到 达 通 信子 网 中 某 一 部 分 的 数据 包 数 量 过 多 ， 
使 得 该 部 分 网 络 来 不 及 处 理 ， 以 致 引起 这 部 分 妃 至 整个 网 络 性 能 下 降 
的 现象 。 当 拥塞 严重 时 ， 甚 至 会 导致 网 络 通信 业务 陷入 停顿 ， 即 出 现 
和 死 锁 现象 。 这 种 现象 跟 公 路 网 中 经 常 所 见 的 交通 拥挤 一 样 ， 在 上 班 高 
峰 时 间 段 中 车 辆 大 量 增加 ， 在 有 限 的 道路 宽度 下 ， 大 量 车 辆 的 涌 入 ， 
使 各 车 辆 的 行驶 速度 大 受 限 制 ， 也 就 出 现 了 拥塞 现象 ， 这 样 每 辆 车 到 
达 目 的 地 的 时 间 都 相对 增加 〈 即 延迟 增加 ) ， 甚 至 有 时 还 会 因 拥塞 而 
长 时 间 无 法 开动 ， 也 就 出 现 了 局 部 死 锁 现象 。 


之 所 以 会 出 现 拥塞 现象 ， 融 征 因为 通信 子 网 中 所 承受 的 负 和 何 〈 即 
通信 子 网 中 正在 传输 的 数据 包 数 ) 超出 了 网 络 的 吞吐 能 力 ( 包 数 / 
秒 ) 。 当 通信 子 网 负荷 比较 小 时 ， 网 络 的 天 吐 量 随 网 络 负 和 荷 的 增加 而 
线性 增加 。 当 网 络 负 三 增加 到 某 一 值 后 ， 此 时 网 络 的 天 吐 量 达到 了 最 
大 值 。 寿 再 加 网 络 负 集 ， 此 时 的 网 络 否 吐 量 会 不 升 反 降 ， 则 表明 网 络 
中 开始 出 现 拥塞 现象 了 。 


忠 像 路 上 的 车 一 样 ， 当 路 上 和 车辆 数 适当 时 ， 车 辆 可 以 正 汕 行驶 。 
但 当 路 上 的 车 辆 数 再 次 增加 时 ， 路 上 的 车 辆 行驶 速度 会 慢 下 来 ， 此 时 
道路 的 吞吐 量 会 降下 来 〈 此 时 的 “吞吐 量 ” 指 每 秒 通 过 的 车 辆 数 ) 。 在 
一 个 出 现 拥 塞 现 象 的 网 络 中 ， 到 达 某 个 结 点 的 数据 包 将 会 遇 到 无 缓冲 


区 可 用 的 情况 ， 进 而 出 现 丢弃 现象 ， 从 而 使 这 些 数据 包 不 得 不 由 源 节 
点 重 传 ， 使 通信 子 网 的 有 效 知 吐 量 下 降 。 由 此 引起 的 恶性 循环 ， 使 通 
信子 网 的 局 部 甚至 全 部 处 于 死 锁 状态 ， 最 终 导致 网 络 有 效 乔 吐 量 接近 
为 零 。 


7.6.1 网络 拥 霍 控 制 方法 


为 了 确保 网 络 的 畅通 ， 你 持 网 络 鸭 有 效 吞 吐 量 ， 束 必须 对 网 络 中 
的 拥塞 现象 进行 有 效 控制 ， 同 时 要 尽量 避免 死 锁 现象 的 发 生 ， 这 融 征 
本 节 要 介绍 的 拥塞 控制 (Congestion Control) 方法 。 但 拥塞 控制 与 流量 
控制 (Flow Control) 不 是 完全 等 同 的 ， 拥 塞 控 制 需 要 确保 通信 子 网 能 
够 承载 用 户 提 区 的 通信 和 量 ， 是 一 个 全 局 性 问题 ， 涉 及 主机 、 路 由 紫 ， 
以 及 与 降低 网 络 传输 性 能 有 关 的 所 有 因素 ， 而 流量 控制 与 点 到 点 的 通 
信 量 有 关 ， 主 要 解决 快速 发 送 方 与 慢 速 接收 方 的 问题 ， 是 局 部 问题 ， 
控制 的 方法 是 抑制 发 送 疹 发 送 数据 的 速率 ， 以 便 使 接收 端 来 得 及 接 
收 ， 一 般 都 是 基于 反馈 进行 控制 的 ， 具 体 可 以 参见 第 5 章 中 介绍 的 流量 
控制 方法 。 


产生 拥塞 的 原因 主要 有 这 三 个 方面 : 结扎 的 缓存 区 容量 太 小 ;和 输 
出 链 路 的 信道 带宽 不 够 ， 处 理 机 的 速度 不 够 快 。 目 前 通常 采用 的 网 络 
拥塞 控制 (Congestion Control) 方法 有 : 绥 冲 区 预 分 配 法 、 数 据 包 丢 弃 
法 和 定额 控制 法 三 种 ， 下 面 分 别 了 予以 介绍 。 


1. 缓 冲 区 预 分 配 法 


缓冲 区 预 分 配 (buffer preallocation) 拥塞 控制 方法 常用 于 虚 电 路 
分 组 交换 网 中 。 在 虚 电 路 建立 时 ， 要 求 呼叫 请 求 分 组 所 途经 的 每 个 结 
扩 为 此 条 虚 电 路 预 完 分 配 一 个 或 多 个 数据 缓冲 区 。 奉 某 个 结 点 当前 无 
可 用 的 缓冲 区 (被 请 求 的 结 点 会 返回 一 个 “ 忙 ” 应 管 信和 号 给 呼叫 请 求 分 
组 发 送 者 ) ， 则 在 建立 虚 电 路 时 ， 让 呼叫 请 求 分 组 选择 其 他 路 径 来 建 
立 虚 电路 。 这 样 ， 通 过 途经 的 各 个 结 点 就 可 以 为 每 条 虚 电 路 开设 永久 
性 的 缓冲 区 〈 直 到 虚 电 路 拆除 ) ， 就 总 能 有 空间 来 接纳 并 转送 经 过 的 
数据 包 。 当 结 点 收 到 一 个 数据 包 并 将 它 转发 出 去 之 后 ， 该 结 点 同 发 送 
结 点 返回 一 个 确认 信息 。 该 确认 一 方面 表示 接收 节点 已 正确 收 到 数据 
包 ; 另 一 方面 告诉 发 送 结 点 ， 该 结 点 已 空 出 缓冲 区 以 备 接收 下 一 个 数 
据 包 。 


打 个 比方 来 说 。 假 设 有 一 批 货物 要 从 甲 地 点 运输 到 乙 地 点 ， 沿 途 
有 A、B、C 三 个 中 转 站 点 《相当 于 虚 电 路 途经 的 中 间 结 点 ) 可 选 ， 如 
图 7-48 所 示 。 因 为 货物 较 多 ， 为 了 提高 货运 周转 率 ， 除 了 要 求 中 转 站 点 
有 较 强 的 转运 能 力 外 ， 还 需要 中 转 站 点 有 较 大 可 用 仓储 空间 (相当 于 
用 于 解决 网 络 拥塞 的 缓冲 区 ) 可 用 ， 以 便 把 那些 中 转 站 点 来 不 及 转运 
的 货物 爷 保 存在 仓库 中 ， 人 否则 有 些 来 不 及 转运 的 货 束 可 能 无 地 可 放 
了 了。 


图 7-48 绥 冲 区 预 分 配 法 


本 来 打算 走 甲 -A-B- 乙 这 条 运输 路 线 ， 不 过 发 货 方 甲 通过 电话 了 解 
到 ，B 站 点 没有 周转 用 的 仓库 (相当 于 中 间 结 点 可 缓冲 区 ) ， 于 是 发 货 
方 甲 打 电话 问 可 选 的 C 阔 点 ， 被 告知 有 仓库 可 用 ， 于 是 最 终 选择 了 申 - 
A-C- 乙 这 条 货运 路 径 。 相 当 于 在 建立 虚 电 路 时 另 选 其 他 路 径 。 


当 货 物 正音 运输 时 ， 每 个 中 转 站 点 都 会 告诉 发 货 方 甲 货物 转运 情 
况 (相当 于 数据 传输 时 接收 方 发 送 的 确认 分 组 ，， 这 时 发 货 方 一 方面 
可 以 得 知 哪些 货物 正音 转运 了 ; 男 一 方面 也 可 售 算出 对 应 中 转 站 点 仓 
库 空间 的 余 量 ， 可 以 更 好 地 安排 发 贷 进度 。 


以 上 只 是 一 种 同一 时 刻 允 许 单 一 数据 包 处 理 的 情况 ， 大 结 点 之 间 
的 协议 允许 多 个 未 处 理 的 数据 包 存 在 ， 则 为 了 完全 请 除 拥塞 的 可 能 
性 ， 每 个 结 点 要 为 每 条 虚 电 路 保留 等 于 窗口 大 小 数量 的 缓冲 区 (相当 


于 图 7-48 所 示 的 示例 中 要 求 中 转 站 点 有 可 以 保存 多 少 吨 货物 的 可 用 仓库 
空间 ) ， 而 且 不 管 实际 上 有 没有 通信 和 量 (也 就 是 相当 于 图 7-41 中 各 中 转 
站 点 的 仓库 是 否 可 以 存 满 货物 ) 。 这 样 一 来 ， 在 实际 的 网 络 通信 中 ， 
会 有 非常 多 的 资源 (线路 容量 或 存储 空间 ) 被 某 个 连接 占有 ， 因 此 网 
络 资 源 的 有 效 利用 率 较 低 。 所 以 ， 这 种 拥塞 控制 方法 主要 用 于 要 求 高 
带宽 和 低 延 迟 的 场合 。 例 如 传送 数字 化 语 首 信息 的 虚 电 路 ， 是 以 牺牲 
资源 来 换取 性 能 保证 的 。 


2. 分 组 丢弃 法 


分 组 丢弃 (Packet Dropping) 拥塞 控制 方法 不 必 有 预先 为 数据 包 预 留 
缓冲 区 ， 而 古 在 路 由 器 的 缓冲 区 已 被 占 满 时 ， 只 需 将 后 面 到 来 的 数据 
包 丢 弃 ， 仪 在 缓冲 区 腾 出 空间 后 再 重新 接收 数据 分 组 。 如 图 7-49 所 示 ， 
从 源 站 点 到 目的 站 点 间 ， 经 过 两 个 路 由 右 ， 当 菏 个 时 刻 路 由 胡 2 发 现 目 
己 的 缓冲 区 满 了 ， 不 能 再 接收 由 路 由 右 1 转 发 来 的 分 组 时 ， 就 会 把 后 来 
发 来 的 分 组 全 部 丢弃 。 如 图 中 的 packet-n 及 以 后 序号 的 分 组 。 在 虚 电 路 
服务 中 ， 通 过 计时 絮 挥 制 方法 可 以 使 发 送 被 丢弃 分 组 的 结 扣 重 发 这 些 
分 组 ， 如 图 中 路 由 器 1 重 发 的 packet-n 分 组 。 很 显然 ， 这 是 一 种 最 直 
授 ， 但 同时 也 是 一 种 最 粗 的 拥塞 控制 方法 ， 因 为 其 直接 拒 收 后 面 到 来 
的 数据 包 。 


packet-m 一 一 人 


有 packet—(n+1)—> 
packet 一 (72+2) 一 一 一 被 丢弃 packet—(n+1) 


“Ns 


图 7-49 “分 组 丢弃 ”拥塞 控制 方法 基本 原理 


packet™n —> 
重 发 


从 这 种 拥塞 控制 方法 的 控制 原理 可 以 看 出 ， 如 有 果 通 信子 网 提供 的 
征 数 据 报 服务 ， 采 用 这 种 拥塞 控制 方法 来 防止 拥塞 的 发 生 则 不 会 引发 
大 的 影响 ， 仍 可 按 前 面 介 绍 的 “缓冲 区 预 分 配 ? 拥 塞 探 制 方法 来 解决 ， 
选择 其 它 路 径 重 新 发 送 ， 如 图 7-48 所 示 。 因 为 在 数据 报 服务 的 分 组 报 文 
中 ， 每 个 分 组 都 有 完整 的 路 由 地 址 信息 ， 可 以 独立 地 选择 最 佳 路 径 进 
行路 由 ， 当 发 现 原 来 的 路 径 性 能 不 佳 时 ， 会 自动 重新 以 其 他 更 好 的 路 
径 进 行 分 组 交换 ， 男 外 ， 在 数据 报 服务 中 ， 接 收 结 点 在 接收 到 分 组 后 
不 需要 进行 确认 ， 所 以 即使 接收 结 点 把 数据 包 丢 弃 了 ， 也 不 会 引起 发 
送 结 点 长 时 间接 等 待 确认 应 答 。 


如 琳 通 信子 网 提供 的 十 虚 电 路 服务 ， 则 必须 在 茶 个 前 面 的 结 扩 中 
保存 了 被 丢弃 数据 包 的 备份 ， 以 便 拥塞 解决 后 能 重新 传送 。 因 为 虚 电 
路 服务 的 分 组 报 文中 ， 没 有 独立 的 路 由 地 址 信息 ， 也 不 能 单独 地 被 路 
由 ， 同 一 数据 包 的 所 有 分 组 必须 走 同一 条 虚 电 路 ， 而 且 要 求 接收 结 点 
在 收 到 每 个 分 组 后 必须 有 确认 应 答 。 如果 虚 电 路 中 某 个 数据 包 的 某 个 


分 组 报 文 被 丢弃 了 ， 发 送 结扎 融 不 会 收 到 对 应 分 组 的 应 答 确 认 。 这 里 
有 两 种 解决 被 丢弃 数据 包 重 发 的 方法 : 一 种 是 束 是 采用 计时 吕方 法 ， 
当 某 个 分 组 发 送 后 ， 在 计时 右 超 时 后 仍 没 有 收 到 接收 结 点 发 回 的 对 应 
分 组 确认 应 答 ， 就 要 使 某 个 转发 该 数据 分 组 的 结 点 重新 发 送 对 应 的 数 
据 分 组 ， 直 至 数据 分 组 被 收 到 ， 毕 竟 每 一 结 点 的 缓冲 区 可 用 空间 是 在 
不 断 动 态 变 化 的 ， 因 为 它们 同时 也 在 不 断 进 行 转发 数据 分 组 ， 男 一 种 
方法 是 让 发 送 被 丢弃 数据 包 的 结 点 在 笑 试 重 发 一 定 次 数 后 放弃 发 送 ， 
并 迫使 数据 源 结 点 超时 而 重新 开始 发 送 。 


3. 定 额 欣 制 法 


定额 控制 拥塞 控制 方法 是 在 通过 通信 子 网 中 设置 适当 数量 称 为 许 
可 证 的 特殊 信息 来 实现 的 。 其 中 一 部 分 许可 证 在 通信 子 网 开始 工作 前 
预先 以 茶 种 策略 分 配给 各 个 源 市 态 ， 男 一 部 分 则 在 子 网 开始 工作 后 在 
网 中 四 处 环 游 。 当 源 世 点 要 发 大 来 目 源 端 系统 的 数据 包 时 ， 它 必须 首 
先 拥有 许可 证 ， 并 且 每 发 送 一 个 数据 包 注 销 一 张 许可 证 。 目 的 市 护 则 
每 收 到 一 个 数据 包 ， 并 将 其 递交 给 目的 端 系统 后 ， 便 生成 一 张 许可 
证 。 这 样 便 可 确保 子 网 中 数据 包 数 不 会 超过 许可 证 的 数量 ， 从 而 防止 
拥塞 的 发 生 。 但 这 时 网 络 的 传输 效率 可 能 不 能 发 挥 到 最 住 。 


其 实 这 种 控制 方法 有 点 像 令 脾 网 上 的 介质 争 用 解决 方案 。 在 令 牌 
网 中 ， 源 让 点 要 发 送 数 据 必须 要 获取 网 络 中 唯一 的 令 脾 不同 的 是 这 
里 的 证 书 不 是 唯一 的 ， 而 是 有 许多 。 


7.6.2” 死 锁 及 其 预防 


和 死 锁 就 是 一 些 结 点 由 于 没有 空闲 缓冲 区 而 无 法 接收 和 转发 数据 包 
(转发 时 也 需要 一 定 的 绥 冲 空间 的 ) 的 现象 ， 死 锁 的 结果 有 是 结 点 间 相 
互 等 待 ， 既 不 能 接收 数据 包 也 不 能 转发 数据 包 ， 并 一 直 保 持 这 一 伪 
局 ， 站 重 时 甚至 导致 整 个 网 络 的 瘫痪 。 死 锁 是 拥塞 的 极端 后 果 ， 是 
络 中 最 容易 发 生 的 故障 之 一 ， 即 使 在 网 络 负 蓓 不 很 重 时 。 此 时 ， 只 
靠 人 工 干 预 来 重新 启动 网 络 (类 似 于 因 死 机 而 进行 的 系统 重启 ) 解 
死 锁 ,但 重新 启动 后 并 不 能 消除 引起 死 锁 的 隐患 ， 所 以 可 能 再 次 发 生 
死 锁 。 下 面 介绍 两 种 常见 死 锁 情 况 及 预防 方法 。 
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(1) 存储 转发 死 锁 及 其 防止 


最 利 见 的 死 锁 是 发 生 在 两 个 结 点 之 间 的 直接 存储 转发 死 锁 。 例 
如 ，A、B 和 C 三 个 结 点 的 缓冲 区 都 满 了 ， 不 能 再 接受 更 多 的 分 组 。A 
的 分 组 都 症 发 往 B 的 ， 而 B 由 于 绥 冲 区 满 了 而 不 能 接收 任何 分 组 。 这 
样 ，A 要 等 到 B 发 送 掉 一 些 分 组 ， 释 放出 缓冲 空间 后 才能 发 送 。B 的 分 
组 是 送 往 C 的 ， 而 C 的 缓冲 区 也 满 了 。C 的 分 组 是 送 往 A 的 ， 而 A 的 缓冲 
区 同样 满 了 。 换 名 话说 ，A 等 待 B 清 空 缓 冲 区 ，B 等 待 C 清 空 缓冲 区 ， 
而 C 则 等 每 A 清空 缓冲 区 ， 但 事实 上 当前 情况 下 ， 这 三 个 结 点 的 缓冲 区 


都 已 无 法 清空 了 。 当 一 个 结 点 处 于 死 锁 状态 时 ， 所 有 与 之 相连 的 链 路 
将 完全 被 拥塞 。 


一 种 防止 存储 处 于 死 锁 的 方法 古 为 每 个 结 点 设置 m+1 个 绥 冲 区 
(m 为 通信 子 网 的 直径 ， 即 从 任 一 源 结 点 到 任 一 目的 结 上 后 间 的 最 大 链 
路 段 数 ) ， 并 顺序 编号 。 每 个 源 结 点 仅 当 其 为 0 号 缓冲 区 可 用 时 才能 接 
收 源 端 系统 来 的 数据 包 ， 而 此 数据 包 仅 能 转发 给 1 扎 缓 神 区 空 朵 的 相 邻 
结 点 ， 再 由 该 结 点 将 数据 包 转 发 给 它 的 2 号 绥 冲 区 空 几 的 相 邻 结 点 ， 以 
此 类 推 。 最 后 ， 该 数据 包 或 顺利 到 达 目 的 结 点 ， 并 被 递交 给 目的 端 系 
统 ; 或 到 了 某 个 结 点 编号 为 m 的 缓冲 区 中 ， 再 也 转发 不 下 去 ， 此 时 一 
定 发 生 了 循环 ， 应 该 将 该 数据 包 丢 弃 。 由 于 每 个 数据 包 都 是 按照 编号 
递增 规则 分 配 缓 冲 区 的 ， 所 以 结 点 之 间 不 会 相互 等 竺 空腹 缓冲 区 而 发 
生死 锁 现 象 。 这 种 方法 的 不 足 之 处 在 于 当 某 结 点 虽然 有 空 几 绥 冲 区 ， 
但 正巧 没有 所 需要 的 特性 编号 的 缓冲 区 时 ， 数 据 包 仍 要 等 待 ， 从 而 造 
成 了 缓冲 区 和 链 路 的 浪费 。 


男 一 种 防止 存储 转发 死 锁 的 方法 是 使 每 个 数据 包 上 都 携 市 一 个 全 
局 性 的 唯一 的 "时 间 玲 >， 每 个 结 点 要 为 每 条 链 路 保留 一 个 特殊 的 接收 
缓冲 区 ， 而 其 他 缓冲 区 均 可 用 于 存放 中 转 数据 包 ， 按 每 条 输出 链 路 的 
队列 上 数据 包 时 间 鹤 顺序 排队 。 例 如 ， 结 点 A 要 将 数据 包 送 到 结 点 B， 
震 B 结 点 没有 空闲 缓冲 区 ， 但 正巧 有 要 送 到 A 结 点 的 数据 包 ， 此 时 A、 
B 结 点 可 通过 特殊 的 接收 缓冲 区 交换 数据 包 ， 厦 B 结 点 既 没 有 空 几 绥 冲 


区 ， 也 没有 要 送 到 A 结 点 的 数据 包 ，B 结 点 只 好 强行 将 一 个 出 路 方向 大 
致 与 A 结 点 方向 相同 的 数据 包 与 A 结 点 数据 包 互 相交 换 ， 但 此 时 A 结 点 
中 的 数据 包 必 须 比 B 结 点 中 的 数据 包 具 有 更 早 的 时 间 难 ， 这 样 才 能 保 
证 子 网 中 某 个 最 早 的 数据 包 不 受阻 挡 地 转发 到 目的 地 。 由 此 可 见 ， 每 
个 数据 包 最 终 总 会 一 步 一 步 地 发 送 到 日 的 结 点 ， 以 此 来 避免 死 锁 现 象 
的 发 生 。 


(2) 重 装 死 锁 及 其 防止 


重 半死 锁 束 是 在 数据 分 组 重新 组 次 、 恢 复 成 原来 数据 包 的 过 程 中 
发 生 的 死 铬 ,是 男 一 种 比较 严重 的 死 锁 现 象 。 假 设 源 结 点 发 送 的 报 文 
很 长 ， 被 源 结 点 拆 成 春 干 个 数据 分 组 发 送 ， 当 这 些 分 组 到 达 目 的 结 点 
后 ， 束 要 将 这 些 具 有 相同 报 文 序 号 的 多 个 分 组 重新 组 效 成 一 个 完整 的 
报 文 再 递交 给 目的 闻 系 统 。 帮 目 的 结 点 用 于 重 狠 报 文 的 缓冲 区 空间 有 
限 ， 而 且 它 无 法 知道 正在 接收 的 报 文 究竟 被 拆 成 多 少 个 数据 分 组 ， 此 
时 惑 可 能 发 生死 锁 现 象 ， 因 为 它 没 办 法 完成 整个 分 组 的 重 又 ， 在 缓冲 
的 分 组 就 不 能 被 发 送出 去 。 而 此 时 相 邻 结 点 仍 在 不 断 地 疝 它 传送 数据 
分 组 ， 因 没有 可 用 的 缓冲 空间 ， 本 结 点 束 无 法 继续 接收 这 些 后 续 的 分 
组 了 。 虽 然 相 邻 结 点 可 以 重 发 ， 但 目的 万 点 的 缓冲 区 始终 得 不 到 清 
空 ， 这 样 源 季 点 在 经 过 多 次 笃 试 后 ， 相 邻 结 点 驶 会 绕道 从 其 他 途径 再 
向 该 目的 端 系统 传送 数据 分 组 ， 但 这 样 做 又 会 造成 周边 区 域 也 由 此 发 
生机 大 %% 


以 下 几 种 方法 可 以 避免 重 闭 死 锁 的 发 生 。 
口 允 许 目的 结 点 将 不 完整 的 报 文 递交 给 目的 端 系统 ， 只 要 按 顺 序 
发 送 即 可 ， 完 整 组 竣 的 任务 交 给 目的 端 系统 


口 检测 出 不 能 完整 重 闭 的 报 文 ， 然 后 要 求 发 送 该 报 文 的 源 端 系统 
重新 传送 ， 但 这 种 方法 的 有 效 性 比较 低 ， 因 为 这 也 很 难 确 保 目 的 节点 
在 重 发 时 就 有 足够 的 缓冲 空间 。 


口 每 个 结 点 配备 一 个 专门 的 缓冲 空间 ， 用 以 暂 存 不 完整 的 报 文 ， 
相当 于 CPU 上 配置 的 多 级 缓存 ， 但 这 明显 会 增加 设备 的 成 本 。 


以 上 前 三 种 方法 中 ， 第 1 种 方法 可 能 使 端 系 统 接收 到 不 完整 的 数据 
报 ， 而 使 整个 数据 无 效 。 第 2 种 方法 使 喘 系 统 中 的 协议 复杂 化 了 ， 同 时 
加 重 了 谣 端 负担 。 第 3 种 方法 虽然 不 涉及 端 系统 ， 但 却 使 每 个 结 点 增加 
了 开销 ， 系 统 性 能 会 大 受 影响 。 


7.7 ”网 络 层 设 备 及 主要 技术 


在 网 络 层 中 ， 目 前 最 主要 的 设备 束 是 路 由 邵 和 三 层 交 换 机 。 路 由 
亏 为 了 实现 不 同 网络 的 互 连 ， 又 包括 了 许多 软 、 和 硬件 技术 ， 如 前 面 介 
绍 的 各 种 路 由 技术 ， 还 有 由 于 路 由 器 是 位 于 网 络 边 界 的 设备 ， 作 为 网 
络 的 唯一 出 口 和 入 口 ， 所 以 它 的 工作 负 谷 也 相当 重 ， 这 也 使 得 路 由 顺 
在 硬件 性 能 方面 有 它 的 特殊 性 所 在 。 主 要 的 路 由 技术 在 前 面 已 有 介 
绍 ， 各 主要 的 路 由 协议 将 在 下 章 再 具体 介绍 ， 下 面 先 来 了 解 一 下 路 由 
亏 的 一 些 主要 硬件 技术 。 


7.7.1 路 由 絮 主 要 便 件 技术 


路 由 融 的 硬件 技术 主要 体现 在 以 下 几 个 方面 。 


1. 硬 件 体系 结构 


路 由 器 的 硬件 体系 结构 大 臻 经历 了 6 次 变化 ， 从 最 早期 的 单 总 线 、 
单 CPU 结 构 发 展 到 单 总 线 、 多 CPU 再 到 多 总 线 多 CPU“。 到 现在 ， 高 速 
IP 路 由 器 中 多 借鉴 ATM 的 方法 ， 采 用 交叉 开关 方式 实现 各 端口 之 间 的 
线 速 无 阻塞 互 连 。 高 速 交 叉 开 关 的 技术 已 经 十 分 成 熟 ， 在 AIM 和 高 速 
并 行 计 算 机 中 早已 得 到 广泛 应 用 。 伴 随 独 高 速 交 叉 开 天 的 引入 ， 一 些 
相应 的 技术 问题 也 同时 被 引入 了 ， 特 别 是 针对 卫 多 播 、 广 播 以 及 服务 


质量 (QoS) ， 引 入 了 一 些 成 熟 的 调度 策略 和 算法 技术 ， 使 这 些 问 题 
都 得 到 了 很 好 的 解决 。 


为 了 缓解 互 连 上 瓶颈， 在 最 近 几 年 涌现 出 许多 狐 的 系统 和 解决 方 
案 ， 其 中 采用 ASIC (专用 集成 电路 ) 来 完成 规定 的 数据 包 处 理工 作 是 
十 分 理想 的 。 但 它 的 开发 周期 太 长 ， 复 杂 的 ASIC 要 18 个 月 到 2 年 时 
间 ， 每 一 个 ASIC 的 开发 都 必须 经 历 一 个 设计 和 制造 的 周期 ， 适 应 不 了 
当今 越 来 越 短 的 产品 开发 周期 。 


在 新 一 代 路 由 器 中 ， 在 关键 的 人 P 业 务 流程 处 理 上 采用 了 可 编程 
的 、 专 为 IP 网 络 设计 的 网 络 处 理 紫 技术 。 它 通过 肴 干 微 处 理 器 和 一 些 
硬件 协 处 理 融 并 行 处 理 ， 通 过 软件 来 控制 处 理 流程 。 对 于 一 些 复杂 的 
操作 (如 内 存 操作 、 路 由 表 查 找 算法 、QoS 的 拥塞 控制 算法 、 流 量 调 
度 算 法 等 ) 采用 硬件 协 处 理 句 来 提高 处 理性 能 。 


网 络 处 理 右 位 于 每 个 线 卡 上 ， 采 用 软件 完成 IP 报 文 处 理 和 转发 ， 
处 理 器 的 软件 可 以 更 新 ， 不 仅 满足 了 业务 发 展 的 需要 ， 而 且 可 提供 线 
速 转发 的 性 能 。 网 络 处 理 器 从 2000 年 年 初出 现 到 现在 被 许多 网 络 设备 
制造 商 选 作 新 一 代 高 端 路 由 需 设 备 的 核心 处 理 右 。 而 在 这 段 时 间 里 ， 
能 够 开发 出 成 熟 的 NPU 蕊 厂 的 公司 也 从 开始 的 两 三 个 迅速 增加 到 了 十 
几 个 ， 而 且 NPU 的 处 理 能 力也 从 2.5Gbps 扩 展 到 10Gbps。 这 些 都 说 明 网 
络 处 理 需 技术 在 网 络 产品 市 场 中 的 位 置 越 来 越 重要 。 尤 其 在 高 端 路 由 


器 市 场 ， 网 络 处 理 器 以 其 杰出 的 包 处 理性 能 及 可 编程 性 已 经 成 为 构成 
路 由 转发 引擎 不 可 替代 的 部 分 。 


2.ASIC 技 术 


在 路 由 句 中 ， 要 极 大 地 提高 速度 ， 首 先 想到 的 是 ASIC，ASIC 可 
以 用 作 包 转发 、 查 路 由 ， 并 且 目 前 已 经 有 专门 用 来 查找 IPv4 路 由 的 商 
用 ASIC 心 厂 。ASIC 技 术 的 应 用 使 路 由 絮 内 的 包 转 发 速度 和 路 由 表 项 
查找 速度 有 了 显著 的 提高 。 


高 速 路 由 器 将 路 由 计算 、 控 制 等 非 实时 任务 同 数据 转发 等 实时 任 
务 分 开 ， 由 不 同 部 分 完成 。 路 由 计算 、 挖 制 等 非 实时 任务 由 CPU 运行 
软件 来 完成 ， 数 据 转 发 等 实时 任务 由 专门 的 ASIC 硬 件 来 完成 。 目 1997 
年 下 半年 以 来 ,一 些 公司 开始 陆续 推出 采用 ASIC 进 行路 由 识别 、 计 算 
和 转发 的 新 型 路 由 器 ， 而 转发 器 负责 全 部 数据 转发 功能 。 


ASIC 技 术 的 进展 意味 着 更 多 的 功能 可 移 向 硬件 ， 提 高 了 性 能 水 
平 ， 增 加 了 功能 。 与 软件 执行 相 比 ，ASIC 的 性 能 是 其 3 倍 。 但 是 全 硬 
件 化 的 路 由 器 使 用 起 来 缺乏 灵活 性 ， 且 会 冒 一 定 的 风险 ， 因 为 标准 规 
范 仍 在 不 断 演变 过 程 中 ， 于 是 出 现 了 可 编程 ASIC。 可 编程 ASIC 和 是 
ASIC 的 发 展 趋势 ， 因 为 它 可 通过 改写 微 码 来 适应 网 络 结构 和 协议 的 变 
化 。 目 前 ， 有 两 种 类 型 的 可 编程 ASIC: 一 种 以 3Com 公 司 的 FIRE 
(Flexible Intelligent Routing Engine) 芯片 为 代表 ; 另 一 种 以 Vertex 


Networks 的 HISC 专 用 心 片 为 代表 ，HISC 心 片 是 一 颗 专门 为 通信 协议 处 
理 而 设计 的 CPU， 通 过 改写 微 码 ， 使 必 片 具有 处 理 不 同 协议 的 能 


3. 分 布 式 处 理 技术 


最 初 的 路 由 大 采用 了 传统 计算 机 体系 结构 ， 包 括 共享 中 央 总 线 、 
中 央 CPU、 内 存 及 挂 在 共享 总 线 上 的 多 个 网 络 物 理 接口 。 接 口 卡通 过 
总 线 将 报 文 传送 到 CPU，CPU 完 成 路 由 计算 、 查 表 、 做 转发 决定 等 处 
理 ， 然 后 又 经 总 线 送 到 另 一 个 物理 接口 并 发 送出 去 。 这 种 单 总 线 单 
CPU 的 主要 局 限 是 处 理 速度 慢 ， 一 颗 CPU 完 成 所 有 的 任务 ， 从 而 限制 
了 系统 的 厨 吐 量 。 另 外 ， 系 统 容错 性 也 不 好 ，CPU 知 出 现 故 障 容易 导 
致 系统 完全 瘫痪 。 这 一 切 都 任 使 传统 路 由 句 的 转发 性 能 很 难 有 大 的 提 
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现代 的 路 由 右 对 报 文 转发 采用 分 布 式 处 理 ， 可 以 插 多 个 线路 处 理 
板 ， 每 个 线路 板 独立 完成 转发 处 理工 作 ， 即 做 到 在 每 个 接口 处 都 有 一 
个 独立 的 CPU， 专 门 负责 接收 和 发 送 本 接口 数据 包 ， 管 理 接收 发 送 队 
列 、 碍 询 路 由 表 并 做 出 转发 决定 等 。 通 过 核心 交换 板 实现 板 间 无 阻塞 
交换 ， 即 一 个 板 上 输入 的 报 文 经 过 寻 路 后 可 以 像 通 过 导线 直 连 那样 ， 
被 交换 到 为 一 个 板 上 输出 ， 实 现 包 交换 ， 其 整 机 否 吐 量 可 以 成 倍 扩 
充 。 而 主 控 CPU 仅 完成 路 由 天 配置 控制 管理 等 非 实 时 功能 。 这 种 体系 
结构 的 优点 是 本 地 转发 /过 滤 数 据 包 的 决定 由 每 个 接口 处 理 的 专用 CPU 
来 完成 ， 对 数据 包 的 处 理 被 分 散 到 每 块 接口 卡 上 。 线 路 板 上 有 专用 心 


片 完成 二 层 、 三 层 力 至 四 层 的 转发 处 理工 作 ， 人 硬件 实现 使 转发 能 够 达 
到 线束 〈 高 速 端口 所 连接 线路 的 速率 ) ， 具 有 了 电路 交换 同样 的 性 
能 ， 使 路 由 融 不 会 成 为 网 络 中 的 瓶颈 。 


然而 ， 单 总 线 结构 路 由 器 存在 一 个 最 大 缺陷 : 一 次 只 能 有 一 个 分 
组 从 入 口交 换 到 出 口 。 如 果 能 在 入 口 和 出 口 之 间 有 多 条 数据 传输 通 
路 ， 则 能 解决 这 种 问题 ， 同 时 可 大 大 提高 系统 的 吞吐 率 。 基 于 这 种 想 
法 ， 同 时 借鉴 ATM 交 换 机 结构 的 优点 ， 提 出 了 基于 交换 机 结构 的 新 一 
代 路 由 器 体系 结构 ， 具 体 可 参见 前 面 的 介绍 。 


4. 交 换 式 结构 和 调度 算法 


交换 结构 有 Cross bar 〈 和 窍 阵 ) 、 共 享 存储 器 和 总 线 三 种 方式 。 甜 
阵 结 构 的 速度 由 调度 絮 决 定 ， 共 至 存 储 絮 结构 的 速度 由 存储 絮 的 读 瑟 
速度 决定 ， 共 享 总 线 结构 的 速度 由 总 线 的 容量 和 仲裁 的 开销 决定 。 


调度 器 是 矩阵 结构 的 核心 ， 它 在 每 个 调度 时 隙 内 收集 各 输入 端口 
有 关 数 据 包 队列 的 信息 ， 经 过 一 定 的 调度 算法 得 到 输入 端口 和 输出 端 
口 之 间 的 一 个 匹配 ， 提 供 输入 端口 到 输出 端口 的 通路 。 采 用 输入 缓冲 
无 阻塞 方式 的 和 矩阵， 用 ESLIP ( (Extended SLIP， 扩 展 Internet 串 行 线 
路 协议 ) 算法 实现 调度 已 被 一 些 厂 家 所 采用 。 调 度 器 设计 的 难点 在 
于 ， 既 要 满足 系统 吞吐 率 达 到 100% 的 要 求 ， 又 要 文 持 CoS (Classes of 
Service， 服 务 级 别 ) 。 调 度 算 法 中 ， 加 权 公 平 排队 算法 (WFQ- 


Weighted Fair Queuing) 和 经 过 改进 后 的 加 权 公 平流 排队 算法 (WF2Q&- 
Weighted Fair Flow Queuing) 比较 容易 实现 ， 而 且 性 能 也 不 钳 。 总 

之 ， 要 让 互联 网 真正 能 够 综合 多 种 业务 ， 作 为 网 络 连接 核心 设备 的 路 
由 器 ， 必 须 提高 端口 速率 和 交换 容量 ， 提 供 QoS 保证 和 流量 工程 (TE- 


Traffic Engineering) 功能 。 


在 交换 结构 中 ， 存 在 单 级 交换 结构 和 多 级 交换 结构 两 种 ， 下 面 分 


别 介绍 。 


(1) 单 级 交换 结构 


单 级 交换 结构 的 引入 隶 步 克服 了 共 至 总 线 的 以 上 缺 上 后。 从 技术 
上 ,目前 使 用 较 多 的 单 级 交换 结构 有 共 译 内 存 和 和 冠 阵 交 换 两 种 。 和 矩阵 
交换 的 结构 由 于 其 简单 性 得 到 了 更 多 的 青睐 和 更 广泛 的 采用 。 共 至 内 
存 结构 是 通过 共 至 输入 输出 站 口 的 缓冲 侨 ， 从 而 减少 了 对 总 存储 空间 
的 需求 。 答 阵 结构 可 以 同时 提供 多 个 数据 通路 。 一 个 矩阵 交换 结构 由 
NxN 交 叉 和 矩阵 构成 。 当 交叉 点 (X，Y) 闭合 时 ， 数 据 就 从 X 输 入 端 输 
出 到 Y 输 出 疾 。 交 义 点 的 打开 与 团 合 是 由 调度 右 来 控制 的 。 因 此 ， 甜 
阵 结构 的 速度 取决 于 调度 右 的 速度 。 调 度 紫 是 矩阵 交换 结构 的 核心 ， 
它 在 每 个 调度 时 际 内 收集 各 输入 端口 有 关 数 据 包 队列 的 信息 ， 经 过 一 
定 的 调度 算法 得 到 输入 端口 和 输出 问 口 之 间 的 一 个 匹配 ， 提 供 输入 站 
口 到 输出 端口 的 通路 。 


和 窍 阵 交换 结构 可 以 文 持 高 市 宽 的 原因 主要 有 两 个 : 首先 ， 线 路 卡 
到 交换 结构 的 物理 连接 已 简化 为 点 到 点 的 连接 ， 这 使 得 该 连接 可 以 运 
行 在 非常 高 的 速率 上 。 半 导体 厂商 目前 已 经 可 以 用 传统 CMOS 技 术 制 
造 出 1Gbps 的 点 对 上 反串 行 收发 芯片 ， 并 且 可 以 在 今后 几 年 里 把 速度 进 
一 步 提高 到 4~10Gbps 的 水 平 。 其 次 是 它 的 结构 可 以 支持 多 个 连接 的 同 
时 能 以 最 大 速度 传输 数据 ， 这 一 点 极 大 地 提高 了 整个 系统 的 吞吐 量 。 
只 要 同时 闭合 多 个 交叉 节点 ， 多 个 不 同 的 端口 束 可 以 同时 传输 数据 。 
从 这 个 意义 上 来 说 ， 我 们 认为 所 有 的 矩阵 在 内 部 十 无 阻塞 的 ， 因 为 它 
可 以 支持 所 有 端口 同时 以 最 大 速率 传输 (或 称 为 交换 ) 数据 。 


数据 包 通 过 和 矩阵 的 时 候 ， 可 以 是 定 长 单元 的 形式 (通过 数据 包 的 
定 长 分 割 ，， 也 可 以 不 进行 分 割 直接 进行 变 长 交换 。 一 般 高 性 能 的 矩 
阵 交 换 结 构 都 采用 了 定 长 交换 的 方式 ， 在 数据 包 进 入 矩阵 以 前 把 它 分 
割 为 固定 长 度 的 cells， 等 这 些 cells 通 过 交换 结构 以 后 再 按照 原样 把 它 
组 织 成 原来 的 变 长 包 。 


共享 内 存 的 特点 是 实现 简单 ， 能 达到 比较 高 的 吞吐 率 ， 但 是 其 可 
扩展 性 比较 过 ， 当 线路 接口 卡 数量 较 多 时 ， 人 性 能 将 受到 一 定 的 影响 。 
而 与 之 对 应 的 交叉 开头 能够 达到 比较 高 的 速率 ， 扩 展 性 好 ， 但 是 需要 
设计 完善 的 调度 算法 并 用 高 速 硬 件 实现 调度 句 。 随 着 人 们 对 交叉 开关 
调度 算法 研究 的 深入 ， 已 经 设计 并 实现 了 许多 性 能 展 好、 实现 简单 的 


调度 算法 。 因 此 ， 目 前 高 性 能 路 由 需 都 趋 问 于 使 用 交叉 开关 作为 交换 
结构 。 交 义 开 关 和 共 训 内存 结 构 都 属于 单 级 交换 结构 范畴 。 


当 考 虑 大 型 系统 时 ， 单 级 交换 结构 有 两 个 基本 问题 。 第 一 、 对 于 
小 规模 系统 ， 端 口 成 本 还 算 合理 ， 但 随 着 规模 的 扩大 ， 其 成 本 涨 得 也 
非常 快 。 第 二 、 所 有 的 单 级 交换 结构 在 技术 上 受 限 于 其 尺寸 与 速度 。 
一 旦 达到 这 些 极限 ， 单 级 交换 机 无 法 再 增加 端口 或 提升 线路 速率 。 正 
因为 如 此 ， 可 扩展 的 交换 系统 必须 采用 多 级 结构 。 


(2) 多 级 交换 结构 


多 级 交换 结构 是 由 多 个 交换 单元 互 连 起 来 的 ， 每 个 交换 单元 具有 
一 整套 输入 输出 ， 与 普通 交换 机 类 似 ， 提 供 输 入 输出 的 连接 。 通 过 互 
连 多 个 小 的 交换 单元 ， 就 可 以 制造 一 个 大 型 的 、 可 扩展 的 交换 结构 。 
多 级 结构 之 间 的 不 同 取决 于 交换 单元 之 间 是 如 何 互 连 的 。 典 型 的 结构 
包括 Benes 网 、Butterfly 网 、Clos 网 等 形式 。 


Benes 网 使 用 方形 交换 单元 (输入 输出 端口 数 相同 进行 多 级 互 
连 。 一 般 来 说 ，3 级 N 部 Benes 网 的 每 一 级 均 可 以 用 N 个 输入 /输出 端口 
和 NN 个 交换 单元 来 构造 。 这 个 格式 结构 在 输入 端 和 输出 端 之 间 形 成 N 个 
可 能 的 通路 。Benes 输 出 可 以 扩展 至 任意 级 数 。 


虽然 对 于 小 型 系统 来 说 单 级 结构 的 设计 相对 简单 ， 成 本 也 相对 
低 ， 但 是 它 不 能 满足 下 一 代 Internet 扩 展 的 需要 。 多 级 结构 在 操作 上 虽 


然 较 复 淋 ,但 是 可 以 扩展 到 成 百 上 千 个 端口 ， 这 对 于 下 一 代 Intemet 核 
心路 由 系统 是 绝对 必要 的 。 在 多 级 拓扑 结构 中 ，Benes 结 构 古 最 佳 选 
择 ， 因 为 它 的 系统 复杂 程度 最 低 ， 性 能 好 且 满 足 可 扩展 的 要 求 。 


5. 路 由 表 硬 件 查 找 技术 


传统 的 基于 软件 的 路 由 查找 策略 ， 如 树 或 哈 希 算法 ， 其 执行 过 程 
都 是 相当 慢 的 ， 而 且 与 路 由 表 的 大 小 相关 联 。 在 路 由 表 更 新 时 ， 输 入 
的 数据 包 必 须 被 缓存 或 丢弃 ， 降 低 了 路 由 旭 的 性 能 。 


为 了 解决 地 址 资源 紧缺 ， 减 少 路 由 表 的 规模 ， 降 低 管 理 难度 ， 互 
联网 采用 了 CIDR (Classless Inter-Doma in Routing， 无 类 域 间 路 由 ) 。 
这 样 ， 路 由 表 中 存放 的 不 是 一 个 个 具体 的 IP 地 址 ， 而 是 可 变 长 度 的 网 
络 前 缀 。 路 由 器 在 对 也 包 寻 址 时 ， 采 用 最 长 的 网 络 前 绥 匹 配 (LPM- 
Longest Prefix Matching) 。 例 如 ， 假 设 路 由 表 中 有 两 个 表 
项 “202.168.X.Xx， 输 出 端口 1”? 和 “202.168.16.X， 输 出 端口 2” (Xx 表示 任 
意 ) ， 如 果 有 一 个 IP 包 的 目的 地 址 为 202.168.16.5， 那 么 这 个 包 应 该 从 
端口 2 输出 。 传 统 的 路 由 器 执行 最 长 网 络 前 级 匹配 的 时 间 很 长 ， 使 得 路 
由 表 查 找 成 为 路 由 器 速度 的 瓶颈 。 近 两 年 出 现 了 一 些 快 速 查 表 算 法 ， 
能 够 支持 吉 比 特 链 路 。 这 些 算法 包括 改进 的 精确 匹配 法 、 基 于 trie ( 线 
索 ) 树 法 、 并 行 硬 件 法 、 协 议 改 变 简化 路 由 表 的 查询 和 缓冲 算法 等 。 
这 些 算法 ， 有 些 适合 人 硬件 实现 ， 有 些 适 合 软件 实现 。 对 于 组 播 地 址 寻 


址 ， 要 根据 IP 包 的 源 地 址 和 组 播 地 址 查 表 ， 对 源 地 址 采用 最 长 前 级 匹 
配 法 ， 对 目的 地 址 采用 精确 匹配 法 。 


基于 软件 的 查找 和 更 新 路 由 表 的 不 确定 性 增加 了 包 传 输 时 的 拌 
动 ， 因 此 必须 进行 包 的 缓存 ， 另 外 其 在 高 速率 时 还 会 造成 丢 包 。 所 
以 ， 这 些 方 法 只 能 用 于 比较 小 的 、 性 能 较 低 的 包 转发 应 用 。 为 了 适应 
网 络 的 发 展 ， 理 想 的 包 转 发 方案 必须 不 但 能 够 保证 线 速 的 数据 转发 速 
率 ， 并 且 能 够 提供 足够 大 的 路 由 表 来 满足 下 一 代 的 路 由 设备 的 需要 
(在 边界 位 置 应 达到 512kB) 。 同 时 它 还 要 能 够 以 很 小 的 更 新 时 延 来 
处 理 长 时 间 的 突 发 路 由 表 更 新 。 尺 管 通常 路 由 表 的 更 新 为 每 秒 几 百 
次 ， 但 瞬间 突 发 更 新 则 可 能 会 高 出 很 多 。 要 解决 这 个 问题 ， 目 前 来 看 
最 为 有 效 的 办 法 是 采用 专门 的 协 处 理 器 结合 内 容 寻 址 寄存 器 (CAM) 
来 完成 快速 路 由 查找 或 更 新 ， 即 硬件 实现 路 由 表 的 查找 。 


> 


6. 高 密度 和 多 端口 


路 由 器 的 高 速 接口 是 建设 大 容量 IP 光 网 的 基础 ， 具 有 高 速 OC-192 
光 接 口 的 高 速 路 由 器 是 网 络 向 IPoverD WDM 结 构 发 展 的 关键 。 在 新 的 
阶段 ， 作 为 互联 网 的 核心 动力 引擎 ， 电 信 运 宫 商 不 仅 对 高 端 路 由 器 的 
处 理 速 度 不 断 提出 新 的 要 求 ， 尤 为 重要 的 是 ， 他 们 开始 关注 其 业务 功 
能 。 运 营 丙 不 仅 需 要 构建 速度 快 的 网 络 ， 更 需要 可 万 利 、 利 于 开展 业 


务 的 核心 网 。 业 务实 现 技术 是 高 端 路 由 噩 能 人 否 符合 电信 企业 实际 运 各 


要 求 的 关键 ， 这 既 包 括 丰 富 的 连接 端口 技术 ， 又 包括 对 增值 服务 的 文 


持 功 能 。 


由 于 运营 商 的 网 络 基础 不 同 ， 应 用 场合 也 千差万别 ， 因 此 要 求 高 
端 路 由 器 有 强大 的 适应 性 和 灵活 性 ， 有 对 各 种 速率 线路 卡 的 支持 能 
力 ， 从 DS3 (一 种 最 高 传输 速率 达 45Mbps 的 网 络 连接 技术 ) 直到 
10Gbps， 并 且 支 持 快 速 以 太 网 / 吉 比 特 以 太 网 、 动 态 分 组 传输 、ATM 
(异步 传输 模式 ) 等 技术 。 它 采用 的 高 密度 方案 能 够 集合 大 量 业务 ， 
包括 基于 ATM 的 话音 业务 、DSL 高 速 接 入 、 专 线 集合 和 互联 网 服务 供 
应 商 集合 ， 可 以 应 用 在 广域网 骨干 、 城 域 网 骨干 、 城 域 网 边缘 、 园 区 
网 骨干 等 多 种 网 络 环境 。 对 用 户 来 说 ， 高 的 端口 密度 具有 重要 的 意 
义 ， 因 为 中 心 局 和 入 网 点 的 空间 资源 不 但 有 限 而 且 成 本 很 高 。 在 巨大 
的 压力 下 ， 业 务 提供 者 已 经 开始 考虑 如 何 市 约 空间 ， 而 具有 高 密度 端 
口 的 高 速 路 由 器 是 解决 空间 压力 的 一 个 重要 方面 。 较 低 的 高 速 端口 密 
度 对 于 今后 的 竞争 是 一 个 不 利 的 因素 ， 目 前 各 路 由 器 厂商 希望 通过 引 
入 新 的 输入 输出 模块 ， 解 决 端口 密度 问题 。 


7. 光 路 由 瑚 扩 术 


新 一 代 Internet 技 术 只 需 部 署 IP 设 备 和 必要 的 光 设 备 、 高 速 路 由 器 
就 可 直接 进入 国家 骨干 网 ， 成 为 国家 核心 网 。 这 意味 着 ， 卫 网 的 协议 
能 够 与 光 网 络 很 好 地 结合 ， 由 原来 的 SDH/SONET 到 主要 支持 IP。 为 了 
达到 这 一 点 ， 核 心路 由 器 应 具备 新 的 光 接 口 、 新 的 网 络 控 制 协议 等 。 


IP over Optical 是 简化 耳 骨 干 网 的 良好 解决 方案 ， 可 以 去 除 昂贵 的 
SONET 和 ATM 设 备 ， 而 且 极 大 地 降低 了 网 络 管理 的 复杂 性 。 但 是 高 速 
路 由 器 直接 连接 到 DWDM 系统 时 ， 网 络 只 有 静态 的 点 到 点 通路 ， 不 人 允 
许 业务 在 不 同 光 通路 间 进 行 交 换 ， 这 导致 了 较 差 的 灵活 性 。 为 解决 此 
问题 ， 国 外 很 多 大 的 运营 商 和 设备 丙 提 出 了 将 光 交 换 机 作为 高 速 路 由 
器 和 DWDM 系统 的 中 间 层 的 概念 ， 进 一 步 将 选 路 和 光 交 换 平 台 综 合成 
光路 由 器 。 使 用 IP 协 议 、 通 过 在 不 同 波长 间 交 换 业 务 、 人 允许 动态 控制 
带宽 等 ， 为 开展 新 业务 提供 了 更 多 的 灵活 性 。 


这 方面 的 技术 进展 完全 源 于 光纤 通信 技术 的 进展 。 随 着 IP 核 心地 
位 逐渐 被 认同 ，IP over ATM 和 ATM over SDH 方 式 直 接 被 IP over SDH 
方式 取代 。SDH 采 用 时 分 复 用 的 方式 承载 多 路 数据 。 因 此 在 核心 网 中 
需 大 量 采 用 复 用 器 交叉 连接 器 ，DWDM (密集 波 分 复 用 ) 使 得 一 根 光 
纤 上 可 用 不 同 的 波长 传送 多 路 信号 。 


光路 由 融 在 网 络 核心 各 光波 长 通道 之 间 设 置 MPLS 协 议和 波长 选 
路 协议 (WaRP) 控制 下 的 波长 选择 器 件 ， 实 现 选 路 交换 ， 快 速 形 成 新 
的 光路 径 。 波 长 的 选 路 路 由 由 内 部 交叉 矩阵 决定 ， 一 个 NxN 的 交叉 矩 
阵 可 以 同时 建立 NxN 条 路 径 ， 波 长 变换 交叉 连接 可 将 任意 光纤 上 的 任 
意 波 长 交叉 连接 到 使 用 不 同 波长 的 任意 光纤 上 ， 具 有 很 高 的 灵活 性 。 


目前 ， 国 内 外 的 电信 设备 供应 商 (TEP) 和 了 HP 设备 供应 商 (IEP) 
都 在 加 紧 研 制 开发 系列 化 的 光 交 换 /光路 由 产品 。 光 路 由 器 产品 主要 有 


Cisco 的 ONS15900 光 路 由 器 ，Corvis 的 CoreWave 光 路 由 器 ，Monterey 
Networks 公 司 的 Monterey 20000 光 路 由 絮 。 


7.7.2 ”路 由 需 主 要 软件 技术 


在 软件 方面 同样 具有 许多 复杂 的 路 由 器 技术 ， 具 体 包括 以 下 儿 个 
方面 。 


1.VPN 技 术 


VPN (Virtual Private Network， 虚 拟 专 用 网 ) 是 路 由 器 的 重要 技 
术 之 一 。VPN 是 指 在 公用 网 络 上 建立 虚拟 私有 网 的 一 种 新 兴 网 络 技 
术 ， 目 前 随 着 技术 的 成 熟 ， 在 各 大 企业 中 应 用 比较 普遍 。VPN 通 信 根 
据 不 同 的 实现 方式 可 以 分 为 如 下 几 种 类 型 。 


按 接 入 方式 划分 ，VPN 可 以 分 为 专线 VPN 和 拨号 VPN 两 类 。 专 线 
VPN 是 为 已 经 通过 专线 接 入 ISP 边 缘 路 由 器 的 用 户 提供 的 VPN 实 现 方 
案 ， 是 属于 Site-to-Site 〈 端 到 端 ) 的 网 络 与 网 络 之 间 互 联 的 VPN 方 
式 ， 在 微软 的 Windows 系 统 中 称 为 路 由 器 到 路 由 器 VPN。 这 类 VPN 通 
信 适 用 于 网 络 用 户 之 间 ， 它 的 发 起 端 可 以 是 双方 的 任意 一 方 。 而 拨号 
VPN 〈 又 称 VPDN) 是 指 利用 拨号 PSTN 或 ISDN 接 入 向 企业 网 络 以 拨号 
方式 进行 的 VPN 通 信 ， 它 属于 Client-to-Site (客户 到 站 点 ) 方式 ， 在 微 
软 的 Windows 系 统 中 称 为 远程 访问 VPN。 这 类 VPN 通 信 适 用 于 移动 用 
户 、 外 出 办 公用 户 ， 它 的 发 起 端 必定 是 拨号 用 户 端 。 


按 协 议 类 型 划分 ，VPN 又 可 以 分 为 第 二 层 隧道 协议 VPN 和 第 三 层 
隧道 协议 VPN 两 类 。 二 层 隧道 协议 VPN 就 是 指 所 进行 的 VPN 通 信 是 利 
用 二 层 隧 道 协议 进行 的 。 二 层 隧道 协议 又 有 点 到 点 隧道 协议 
(PPTP) 、 第 二 层 转发 协议 (L2F) 和 第 二 层 隧道 协议 (L2TP) 三 
种 ， 凡 是 采用 这 三 种 隧道 协议 之 一 的 VPN 通 信 均 为 第 二 层 隧 道 协 议 
VPN。 第 三 层 隧 道 协 议 VPN 是 指 利用 第 三 层 隧道 协议 进行 的 VPN 通 
信 ， 第 三 层 隧 道 协议 又 有 通用 路 由 封装 协议 (GRE) 和 IP 安 全 
(IPSec) 协议 两 种 ， 最 常用 的 是 IPSec 安全 协议 。 目 前 的 VPN 通 信 基 
本 上 是 第 二 层 隧道 协议 与 第 三 层 隧 道 协议 的 有 机 结合 ， 如 L2TP+IPSec 
协议 的 VPN 通 信 。 


路 由 器 是 VPN 通 信 中 非常 重要 和 关键 的 设备 ， 绝 大 多 数 企 业 网 络 
之 间 的 VPN 通 信和 是 通过 路 由 万 发 起 的 。 当 然 在 整个 YPN 通 信 市 场 中 ， 
除了 采用 路 由 絮 外 ， 还 有 采用 交换 机 、 集 中 右 和 远程 访问 服务 紫 进 行 
的 ， 这 些 VPN 方 案 均 有 它们 各 目 不 同 的 技术 特 。 


2.QoS 技 术 


QoS (Quality of Service， 服 务 质量 ) 原先 是 ATM 网 络 中 中 专用 
的 ， 但 利用 IP 传 输 VOD (Video On Demand， 视 频 点 播 ) 等 多 媒体 信 
息 的 应 用 越 来 越 多 ， 了 作为 一 个 打包 的 协议 显得 有 点 力不从心 ， 这 主 
要 体现 在 : 延迟 长 且 不 为 定 值 ， 丢 包 造 成 信号 不 连续 且 失 真 大 。 为 解 
决 这 些 问题 ， 厂 商 提 供 了 若干 解决 方案 : 第 一 种 方案 是 基于 不 同 对 象 


的 优先 级 ， 某 些 设备 (多 为 多 媒体 应 用 ) 发 送 的 数据 包 可 以 后 到 先 
传 ， 第 二 种 方案 基于 协议 的 优先 级 ， 用 户 可 定义 哪 种 协议 优先 级 高 ， 
可 后 到 先 传 ，Intel 和 Cisco 都 文 持 ， 第 三 种 方案 是 进行 链 路 整合 MLPPP 
(Multi Link Point to Point Protocol， 多 链 路 点 对 点 协议 ) ，Cisco 支 持 
将 连接 两 点 的 多 条 线路 进行 带宽 汇聚 ， 从 而 提高 带宽 ， 第 四 种 方案 
进行 资源 预 留 RSVP (Resource Reservation Protocol， 资 源 预 留 协 

议 ) ， 它 将 一 部 分 带宽 固定 的 分 给 多 媒体 信号 ， 其 他 协议 无 论 如 何 拥 
挤 ， 也 不 得 占用 这 部 分 带宽 。 这 几 种 解决 方案 都 能 有 效 提 高 传输 质 


时 


里 ” 


下 面 简 单 介绍 与 QoS 有 关 的 路 由 器 技术 。 
(1) 数据 包 分 类 技术 


IPv4 包 头 中 有 一 个 3 位 的 区 域 用 以 标识 此 IP 包 的 优先 级 。 据 此 优先 
级 ，IP 路 由 器 可 以 决定 不 同 IP 包 的 转发 优先 顺序 。 可 以 说 ， 目 IP 协 议 
制定 之 日 起 ， 束 为 日 后 提供 更 好 的 QoS 做 了 准备 。 


路 由 器 对 到 达 的 分 组 包 进 行 识别 、 分 类 以 决定 其 所 应 接受 的 服务 
类 型 。 当 初 ITF 所 考虑 的 方案 是 在 网 络 的 核心 ， 根 据 卫 报头 的 ToS 
(Type of Service， 类 型 服务 ) 域 来 识别 分 组 ， 但 是 在 互联 网 的 发 展 过 
程 中 ， 由 于 一 直 采 用 “尽力 ”传输 模式 ， 同 时 由 于 终端 在 发 送 IP 包 时 不 
考虑 ToS， 因 此 ，ToS 一 直 没 有 发 挥 作用 。 目 前 在 边 绿 设备 ， 根 据 IP 分 


组 的 源 IP 地 址 、 目 的 耳 地 址 、 源 端口 号 、 目 的 端口 号 、 传 输 层 协议 类 
型 来 对 分 组 进行 识别 。 此 外 ， 为 了 实现 防火 墙 的 功能 也 需要 对 IP 分 组 


进行 识别 。 


在 识别 时 ， 每 条 识别 规则 采用 的 是 源 IP 地 址 、 目 的 IP 地 址 、 源 端 
口号 、 目 的 端口 号 、 传 输 层 协议 类 型 。 在 上 述 识别 规则 中 ， 每 个 域 都 
可 能 是 一 个 区 间 。 例 如 有 这 样 一 条 识别 规则 “126.66.64.X， 
126.66.72.X，X，23，TCP” (X 表 示 任 意 ) ， 这 条 规则 识别 从 网 络 
126.66.64.X 到 网 络 126.66.72.X 的 telnet 数 据 。 从 几何 的 角度 来 看 ， 假 如 
判别 时 利用 了 IP 报 头 的 K 个 域 ， 则 这 个 问题 实际 上 是 在 一 个 K 维 空间 中 
有 许多 互相 交 到 的 实体 (每 条 判别 规则 对 应 于 一 个 实体 ) ， 每 当 有 一 
个 分 组 到 达 时 ， 该 分 组 相当 于 K 维 空间 上 的 一 个 点 ， 进 行 判 别 实际 上 
是 要 找 出 包含 该 点 的 优先 级 最 高 的 实体 。 


(2) 数据 流 的 分 类 


一 系列 通过 给 定 的 产 和 目的 地 的 数据 包 被 视 为 数据 流 ， 数 据 流 可 
以 是 长 时 间 维持 的 TCP 连 接 的 一 系列 数据 包 ， 也 可 以 是 声音 或 图像 的 
一 系列 UDP 数据 包 。 通 前 ， 流 有 长 短 之 分 ， 划 分 有 两 个 标准 : 端口 对 
和 主机 对 。 按 靖 口 对 划分 是 指 同一 流 的 数据 包 必 须 具 有 相同 的 源 、 目 
的 地 址 和 TCP/UDP 端 口号 等 ， 按 主机 对 划分 只 要 求 各 数据 包 具 有 相同 
的 源 和 目的 地 址 。 目 前 冰 用 的 流 分 类 大 有 三 种 ， 一 种 是 X/Y 分 类 郁 ，Y 
为 规定 的 时 间 间 隔 ，X 为 数据 包 数 。 帮 在 时 间 Y 内 某 一 数据 流 到 达 的 数 


据 包 数 大 于 X， 则 该 流 就 被 认定 为 长 数据 流 ， 否 则 是 短 数据 流 ， 男 一 
种 是 协议 分 类 器 (Protocol Classifier) ， 它 规定 了 所 有 的 TCP 包 均 被 定 
义 为 数据 流 ， 还 有 一 种 是 端口 分 类 器 (Port Classifier) ， 它 规定 了 几 
个 特殊 的 TCP 端 口 作为 长 数据 流 。 因 为 分 类 要 对 每 个 进入 路 由 器 的 包 
进行 包头 检查 ， 需 要 快速 的 分 类 算法 。 
(3) RSVP (资源 预 留 协 议 ) 技术 

这 是 IP 路 由 器 为 提供 更 好 的 服务 质量 向 前 迈进 的 具有 深刻 意义 的 
一 步 。 传 统 IP 路 由 器 只 负责 包 转 发 ， 通 过 路 由 协议 知道 邻近 路 由 器 的 
地 址 。 而 RSVP 则 类 似 于 电路 交换 系统 的 信 令 协议 ， 为 一 个 数据 流通 知 
其 所 经 过 的 每 个 结 点 〈IP 路 由 器 ) ， 与 端点 协商 为 此 数据 流 提供 质量 
保证 。 


(4) DiffServ 技 术 


近年 来 ，IETF 又 新 推出 另 一 种 QoS 策略 
(Differentiated Service， 差 别 服务 ) 。 目前 DiffServ 的 框架 已 基本 确 
定 ， 美 国 的 Internet2 也 选择 DiffSserv 作 为 其 QoS 策略 。 与 DiffServ 相 比 ， 
RSVP 是 一 种 Integrated Service (集中 控制 策略 ) ， 而 DiffServ 则 是 一 种 
分 散 控 制 策 略 ， 其 精髓 是 仅 控制 路 径 中 的 每 一 行为 。 终 端 应 用 设备 通 
过 SLA (Service Level Agreement， 服 务 级 别 协定 ) 与 边缘 路 由 器 协商 


DiffServ 


获得 其 应 用 数据 流 可 得 到 保证 的 服务 级 别 。 除 此 之 外 ， 多 协议 标记 交 
换 (MPLS) 也 常 被 用 来 解决 QoS 问题 。 


3.MPLS 技 术 


IP 网 络 的 发 展 存在 着 一 个 非常 明显 的 障碍 ， 这 是 由 IP 协 议 本 身 固 
有 的 一 个 缺陷 决定 的 ， 那 就 是 它 是 一 个 无 连接 的 协议 ， 因 此 IP 网 络 上 
的 应 用 无 法 得 到 很 好 的 QoS 保证 。 由 于 缺乏 连接 性 ， 每 一 个 也 包 都 是 
单独 发 到 目的 地 的 ， 网 络 中 的 各 个 结 点 都 无 从 知晓 这 些 无 连接 的 包 中 
的 某 一 个 是 如 何 到 来 的 。 与 此 相 比 ， 面 向 连接 的 协议 ， 如 帧 中 继 则 需 
要 建立 一 个 固定 的 虚 电 路 。 连 接 路 径 上 的 各 个 结 点 以 及 干线 可 以 先 为 
其 预 留 资源 ， 以 提供 QoS 保证 。 但 也 是 因为 它 的 无 边 接 性 ，IP 协 议 却 
具有 其 他 网 络 协议 所 无 法 比拟 的 灵活 性 ， 这 一 点 通过 Internet 已 经 得 到 
了 证 明 。 如 果 能 结合 这 两 类 协议 则 肯定 是 非常 有 意义 的 ， 而 且 结合 后 
的 协议 还 能 具有 两 类 协议 的 优点 ， 那 应 用 效果 会 更 好 。 就 是 在 这 样 一 
种 思想 下 产生 了 MPLS (Multi Protocol Label Switch， 多 协议 标记 交 
换 ) 协议 。MPLS 结 合 的 是 IP 路 由 和 标记 交换 这 两 种 技术 ，IP 路 由 当然 
是 耳 协议 的 功能 了 ， 而 标记 交换 原先 则 是 ATIM 这 类 有 连接 协议 的 功 
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MPLS 在 网 络 入 口 的 边缘 路 由 器 (LER) 为 每 个 包 加 上 一 个 固定 长 
度 的 标签 ， 核 心路 由 器 根据 进入 包头 的 标记 值 进行 标记 交换 ， 作 出 本 
地 转发 决定 ， 在 出 口 的 边 毕 路 由 絮 再 恢复 原来 的 IP 包 。 从 入 口 到 出 口 


的 一 连 串 这 样 的 标记 交换 和 转发 决定 操作 ， 形 成 了 一 条 标记 交换 路 
径 。MPLS 古 处 于 第 二 层 和 第 三 层 之 间 的 一 种 技术 ， 它 紧密 地 将 第 二 
层 和 第 三 层 结合 在 一 起 ， 充 分 发 挥 了 第 二 层 的 交换 、 流 量 管 理 上 的 优 
势 ， 同 时 ， 它 还 兼顾 了 第 三 层 路 由 、 寻 径 灵 活 的 优势 。 


MPLS 之 所 以 吸引 了 学 术 界 、 产 品 制造 商 和 运营 商 的 注意 力 ， 除 
去 MPLS 的 快速 转发 将 为 运营 商 和 大 型 企业 带 来 众多 的 利益 外 ， 最 重 
要 的 原因 它 承诺 为 卫 网 络 提供 类 似 于 ATM 网 络 的 控制 和 安全 性 ， 能 够 
开展 虚拟 专用 网 (VPN) 业务 ， 做 IP 网 上 的 流量 工程 (TE) 以 及 提供 
服务 质量 (QoS) 保证 等 。 也 就 是 说 ，MPLS 既 可 以 克服 IP 的 一 些 致命 
缺点 ， 又 可 以 利用 耳 的 很 多 优点 。 


电信 级 的 可 靠 性 是 运 膏 商 永 恒 的 要 求 ， 新 型 的 核心 路 由 右 引 入 了 
先进 的 见 余 备份 方案 例如 交换 矩阵 “1+1” 备 份 、 接 口 板 “1:N” 备 份 ， 
从 而 确保 了 网 络 无 中 断 运 行 。 在 电信 级 卫 网 络 实际 运行 中 ， 设 备 的 调 
整 是 不 可 避免 的 ， 核 心路 由 亏 的 所 有 接口 板 都 具有 热 插 拔 功能 。 由 于 
有 元 余 备 份 方案 ， 又 采用 区 换 式 育 板 ， 因 此 热 插 拔 不 会 造成 数据 包 丢 
失 。 但 是 如 采 采 用 高 速 级 存 的 方式 ， 束 无 法 保证 数据 安全 转发 ， 给 维 
护 工作 市 来 磋 烦 。 例 如 ，A 接 口 板 的 包 可 能 因为 网 络 拥塞 放 在 B 接 口 板 
上 备份 ， 一旦 对 B 板 进行 热 插 拔 ， 数 据 包 束 会 出 现 丢 失 。 控 作 系统 古 
高 端 路 由 硕 的 软件 核心 ， 主 要 实现 路 由 引擎 功能 ， 所 以 操作 系统 的 稳 
健 性 直接 关系 到 系统 的 性 能 。 这 要 求 软件 不 仅 文 持 的 路 由 协议 最 为 全 


面 ， 更 为 重要 的 是 ， 当 网 络 出 现 故 障 时 ， 软 件 系统 应 有 很 强 的 路 由 “学 
习 ? 能 力 ， 可 以 在 很 短 的 时 间 内 建立 最 优 的 路 由 表 ， 便 于 最 大 限度 地 缩 
短 故 障 时 间 ， 恢 复 运 营 服 务 。 


MPLS 将 IP 的 灵活 性 和 帧 中 继 、ATM 等 面向 连接 网 络 的 QoS 保 证 特 
性 有 效 地 结合 在 了 一 起 ， 这 对 于 IP 的 进一步 广泛 应 用 无 疑 有 着 巨大 的 
推动 作用 。 


4. 多 播 技术 


多 播 (Multicast) 主要 用 于 视频 会 议 等 应 用 场合 ， 这 种 应 用 需要 
同一 份 数 据 同 时 发 送 给 多 个 用 户 。 多 播 包 的 目的 地 址 使 用 DD 类 IP 地 
址 ， 即 224.0.0.0~239.255.255.255 这 个 地 址 段 。 每 个 多 播 地 址 代表 一 个 
多 播 组 ， 而 不 是 一 台 主 机 。IGMP (Internet 组 管理 协议 ) 用 于 控制 用 
户 加 入 或 离开 多 播 组 ， 多 播 路 由 协议 则 用 于 建立 多 播 路 由 表 (或 称 多 
播 树 ) 。 


如 有 条 一 个 局 域 网 中 有 一 个 用 户 通过 IGMP 宣 布 加 入 某 多 播 组 ， 则 局 
域 网 中 的 多 播 路 由 媚 吏 将 该 信息 通过 多 播 路 由 协议 进行 传播 ， 最 终 将 
该 局 域 网 作为 一 个 分 村 加 入 多 播 树 。 当 局 域 网 中 的 所 有 用 户 退 出 该 多 
播 组 后 相关 的 分 校 束 从 多 播 树 中 删 控 。 多 播 网 中 可 能 有 不 文 持 多 播 的 
路 由 器 ， 此 时 多 播 路 由 器 使 用 IP over IP 的 隧道 方式 将 多 播 包 封 装 在 单 


播 了 P 包 中 透 传 给 相 邻 的 多 播 路 由 闫 。 相 邻 的 多 播 路 由 右 再 将 单 播 I 头 
剥 掉 ， 然 后 继续 进行 多 播 传输 。 


5. 网 管 系统 


网 管 系统 在 网 络 运 营 中 起 着 非常 重要 的 作用 。 方 便 、 强 大 的 网 管 
系统 可 以 协助 用 户 有 效 地 管理 网 络 和 降低 网 络 维护 费用 。 网 管 协议 非 
常 多 ， 与 路 由 器 产品 相关 的 网 管 协议 主要 有 SNMP 《简单 网 络 管理 协 
议 ) 、RMON (远程 镜像 ) 等 ， 其 中 SNMP 最 常见 。SNMP 采 用 代理 
(Agent) 工作 方式 ， 设 备 侧 (路 由 器 上 ) 运行 Agent， 网 管 站 运行 管 
理 软件 。 代 理 的 作用 包括 收集 路 由 器 统计 数据 “如 端口 收发 报 文 总 数 
等 ) 和 状态 信息 《如 端口 地 址 等 ) ， 回 答 网 管 站 对 这 些 信息 的 查询 ; 
传达 网 管 站 的 设置 命令 ， 如 TCP 连 接 复位 、 配 置 端口 I[P 地 址 、 发 生 异 
常事 件 时 主动 向 网 管 站 报告 等 。 


7.73 三 层 交 换 机 


早期 的 网 络 中 一 般 使 用 二 层 交 换 机 来 搭建 局 域 网 ， 而 不 同 局 域 网 
之 间 的 网 络 互通 由 路 由 器 来 完成 ， 如 图 7-50 所 示 。 那 时 的 网 络 流量 中 ， 
局 域 网 内 部 的 流量 占 了 绝 大 部 分 ， 而 网 络 间 的 通信 访问 量 比较 少 ， 使 
用 少量 路 由 咯 已 经 足够 应 付 了 。 


Internet 


图 7-50 二 层 交 换 机 + 路 由 絮 组 网 基本 结构 


随 着 数据 通信 网 络 范 围 的 不 断 扩 大 ， 网 络 业务 的 不 断 丰 富 ， 网 络 
间 互 访 的 需求 越 来 越 大 ， 而 路 由 器 由 于 自身 成 本 高 、 转 发 性 能 低 、 端 
口 数量 少 等 特点 无 法 很 好 地 满足 网 络 发 展 的 需求 。 我 们 知道 ， 路 由 器 
主要 是 通过 IP 转 发 〈 三 层 转发 ) 来 实现 不 同 网 络 间 的 互 连 ， 那 么 是 否 


能 够 将 交换 机 的 高 性 能 应 用 到 三 层 转发 中 去 呢 ? 答案 是 肯定 的 ， 三 层 
交换 机 就 是 这 样 一 种 实现 了 高 速 三 层 转发 的 设备 。 其 典型 网 络 结构 如 
图 7-51 所 示 。 
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图 7-51 三 层 交 换 机 组 网 基本 结构 


大 多 数 三 层 交 换 机 采用 ASIC 人 硬件 已 片 来 完成 转发 ，ASIC 心 厂 内 部 
集成 了 IP 三 层 转 发 的 功能 ， 包 括 检查 IP 报 文 涉 、 修 改 存活 时 间 (TTL) 
参数 、 重 新 计算 IP 头 校 验 和 、 封 装 IP 包 的 数据 链 路 等 。 


7.7.4 三 层 交 换 机 人 硬件 结构 


总 体 来 说 ， 目 前 的 三 层 交 换 机 在 三 层 路 由 模块 中 有 三 种 类 型 ， 即 
纯 硬 件 模块 、 纯 软件 模块 和 软 /硬结 合 模块 三 大 类 。 目 前 最 常见 的 还 是 
软 /硬件 结合 的 三 层 路 由 模块 。 


1. 纯 软件 路 由 模块 的 三 层 交 换 机 


在 早期 ， 以 及 目前 比较 低档 的 三 层 交 换 机 中 基本 上 都 是 采用 纯 软 
件 路 由 模块 来 实现 三 层 交 换 功 能 的 。 这 类 三 层 交 换 机 的 基本 内 部 结构 
如 图 7-52 所 示 。 在 这 种 三 层 交 换 机 中 ， 是 通过 CPU 调 用 相关 的 软件 功 
能 ， 查 询 存 储 在 内 存 中 的 CAM (Content Addressable Memory， 内 容 可 
寻 址 记忆 ) 表 来 获取 对 应 目的 JP 地址 和 和 MAC 地址。 


(存储 CAM 表 ) 


交换 机 端口 电路 


7-52” 纯 软件 路 由 模块 的 三 层 交 换 机 基本 内 部 结构 


2. 纯 硬件 路 由 模块 的 三 层 交 换 机 


纯 硬 件 的 三 层 交 换 撤 术 相 对 来 说 技术 复杂 、 成 本 高 ， 但 是 速度 
快 、 性 能 好 、 带 负载 能 力 强 。 其 原理 是 采用 专门 的 ASIC 必 请 进 行路 由 
表 的 查找 和 刷新 ， 如 图 7-53 所 示 。 


一 ASIC 芯 片 
(存储 路 由 表 ) 


二 层 交 二 层 交 换 芯 片 
换 模 块 (存储 CAM 表 ) 


交换 机 端口 电路 


图 7-53 纯 人 硬件 路 由 模块 的 三 层 交 换 机 基本 内 部 结构 


这 种 纯 硬 件 路 由 模块 的 三 交换 机 在 数据 交换 原理 方面 与 纯 软 件 路 
由 模块 的 三 层 交 换 机 基本 一 样 ， 不 同 的 只 是 这 里 在 进行 路 由 转发 时 采 
用 的 是 ASIC 心 片 ， 路 由 表 信 息 也 是 存储 在 ASIC 心 片 中 ， 执 行 效率 更 


高 。 
3. 软 /硬件 结合 路 由 模块 的 三 层 交 换 机 


目前 纯 软 件 或 者 纯 硬件 路 由 模块 的 三 层 交 换 机 都 比较 少见 ， 比 较 
常见 的 是 两 者 的 结合 的 三 层 交 换 机 ， 在 ASIC 心 厂 中 同时 存储 二 层 
CAM 表 和 三 层 转 发 表 ， 在 内 存 中 存储 软件 路 由 表 和 ARP 表 ， 由 CPU 调 
用 ， 既 利用 硬件 模块 的 高 速 交 换 性 能 ， 又 利用 软件 模块 的 灵活 性 。 


以 上 ASIC 世 片 用 来 完成 主要 的 二 、 三 层 转发 功能 ， 内 部 包含 用 于 
二 层 转 发 的 MAC 地 址 表 以 及 用 于 了 P 转 发 的 三 层 转 发 表 ;， CPU 主要 用 于 
转发 的 控制 ， 维 护 一 些 软件 表 项 (包括 软件 路 由 表 、 软 件 ARP 表 
等 ) ， 并 根据 软件 表 项 的 转发 信息 来 配置 ASIC 的 硬件 三 层 转 发 表 。 当 
然 ，CPU 本 身 也 可 以 完成 软件 三 层 转 发 ， 这 就 是 前 面 介绍 的 纯 软件 三 
层 路 由 模块 的 三 层 交 换 机 。 


从 三 层 交 换 机 的 结构 和 各 部 分 作用 可 以 看 出 ， 真 正 决 定 高 速 交 换 
转发 的 是 ASIC 中 的 二 、 三 层 硬件 表 项 ， 而 ASIC 的 人 硬件 表 项 来 源 于 CPU 
维护 的 软件 表 项 。 


7.7.5 ”三 层 交 换 原 理 


二 层 交 换 机 的 二 层 数 据 交换 一 般 都 是 使 用 ASIC (Application 
Specific Integrated Circuit， 专 用 集成 电路 ) 的 硬件 芯 厂 中 的 CAM 表 来 实 
现 的 ， 因 为 是 硬件 转发 ， 所 以 转发 性 能 非常 高 。 而 三 层 交 换 机 的 三 层 
转发 也 是 依靠 ASIC 心 片 完 成 的 《路 由 器 的 路 由 功能 主要 依靠 CPU 软件 
进行 的 ) ， 但 其 中 除了 二 层 交 换 用 的 CAM 表 外 ， 还 保存 有 专门 用 于 三 
层 转发 的 三 层 硬 件 转发 表 。 


三 层 交 换 机 的 三 层 交 换 原 理 比 较 复 杂 ， 不 同 网 络 环境 下 不 同 三 家 
的 三 层 交 换 机 的 三 层 交 换 流 程 都 不 完全 相同 。 图 7-54 所 示 的 仅 是 一 个 直 
接连 接 在 一 台 三 层 交 换 机 上 的 两 个 不 同 网 段 主 机 三 层 交 换 的 基本 流 
程 ， 其 各 主要 步 又 解释 如 下 : 


i 主机 以 网 关 的 IP 地 在 无 目的 主机 和 接 PU 发 这 一 不 [MX 卓识 
址 为 目的 了 p 地 址 发 闫 的 三 层 硬件 转发 . CPU 所 以 的 吕 的 
为 1 


二 生 请 求 报 转发 表 项 ? 
着 以 获得 网 关 的 MAC 六 WW 手 来 


源 主机 以 网 关 MAC 地 任 CPU 路 由 表 ' 
址 作 为 目的 MAC 地 址 回 二 守 目 肯 主机 的 需要 配置 中 全 人 加 中 
网 关 发 送 要 到 达 目 的 主机 路 由 表 项 ? 下 六 a 
的 全 数据 包 ( 包 中 的 目 和 
I 各 对 应 的 路 由 表 需 生 成 目的 
主机 的 三 层 硬 件 转发 表 项 


人 在 ARP 表 中 有 

上 传 多 :交换 硬件 引 无 目的 主机 的 

葡 (AS 1 )， 同 时 生 MAC 地 址 表 项 ? 
成 源 主 机 的 关 各 淹 件 轿 改 
表 项 


图 7-54 三 层 交 换 基 本 流程 


1) 源 主机 在 发 起 通信 之 前 ， 将 自己 的 IP 地 址 与 目的 主机 的 IP 地 址 
进行 比较 ， 如 果 源 主机 判断 目的 主机 与 自己 位 于 不 同 网 段 时 ， 则 它 需 
要 通过 网 关 来 递交 报 文 ， 所 以 它 首 先 需 要 通过 一 个 ARP 请 求 报 文 获取 
网 关 的 MAC 地 址 (在 源 主机 不 知道 网 关 MAC 地 址 的 情形 下 ) ， 即 源 主 
机 先 发 送 ARP 请 求 帧 以 获取 网 关 IP 地 址 对 应 的 MAC 地 址 。 


2) 网 关 在 收 到 源 主 机 发 来 的 ARP 请 求 报 文 后 以 一 个 ARP 应 答 报 文 
进行 回应 ， 在 应 答 报 文中 的 源 MAC 地 址 就 是 网 关 的 MAC 地 址 。 


3) 在 得 到 网 关 的 ARP 应 答 后 ， 源 主机 再 用 网 关 MAC 地 址 作为 报 文 
的 目的 MAC 地 址 ， 以 源 主机 的 IP 地 址 作为 报 文 的 源 IP 地 址 ， 以 目的 主 
机 的 IP 地 址 作为 目的 IP 地 址 ， 先 把 发 送 给 目的 主机 的 数据 发 给 网 天 。 


4) 网 关 在 收 到 源 主机 发 送 给 目的 主机 的 数据 后 ， 由 于 查看 得 知 源 
主机 和 目的 主机 的 人 P 地 址 不 在 同一 网 段 ， 于 是 把 数据 报 上 传 到 三 层 交 
换 引 警 (ASIC 必 片 ) ， 在 里 面 查 看 有 无 目的 主机 的 三 层 转发 表 。 


5) 如 果 在 三 层 硬 件 转发 表 中 没有 找到 目的 主机 的 对 应 表 项 ， 则 向 
CPU 请 求 碍 看 软件 路 由 表 ， 如 果 有 目的 主机 所 在 网 段 的 路 由 表 项 ， 则 
还 需要 得 到 目的 主机 的 MAC 地 址 ， 因 为 数据 包 在 链 路 层 是 要 经 过 帧 孝 
装 的 。 于 是 三 层 交 换 机 CPU 向 目的 主机 所 在 网 段 发 送 一 个 ARP 广 播 请 
求 包 ， 以 获得 目的 主机 MAC 地 址 。 


6) 交换 机 获得 目的 主机 MAC 地 址 后 ， 向 ARP 表 中 添加 对 应 的 表 
项 ， 并 转发 由 源 主机 到 达 目 的 主机 的 数据 包 。 同 时 三 层 交 换 机 三 层 引 
警 会 结合 路 由 表 生 成 目的 主机 的 三 层 硬件 转发 表 。 


以 后 到 达 目 的 主机 的 数据 包 束 可 以 直接 利用 三 层 人 硬件 转发 表 中 的 
转发 表 项 进行 数据 交换 ， 不 用 再 查看 CPU 中 的 路 由 表 了 。 


以 上 流程 适用 位 于 不 同 VLAN (网 段 ) 中 的 主机 互 访 的 情况 ， 这 时 
用 于 互 连 的 交换 机 做 三 层 交换 转发 。 


7.7.6 ”三 层 交 换 示 例 


在 三 层 交 换 中 ， 同 一 交换 机 上 的 不 同 网 段 主 机 通信 和 不 同 交换 机 
上 的 不 同 网 段 主机 通信 的 基本 原理 是 一 样 的 ， 只 是 具体 流程 有 所 区 
别 。 本 节 仅 以 比较 简单 的 “同一 交换 机 上 的 不 同 网 段 主 机 通信 * 这 种 情 
形 来 解释 上 节 介 绍 的 三 层 交 换 原 理 。 

如 图 7-55 所 示 ， 通 信 的 源 、 目 的 主机 连接 在 同一 台 三 层 交 换 机 上 ， 
但 它们 位 于 不 同 VLAN (即位 于 不 同 网 段 )。 对 于 三 层 交 换 机 来 说 ， 这 
两 台 主 机 都 位 于 它 的 直 连 网 段 内 ， 它 们 的 卫 对 应 的 路 由 都 是 直 连 路 
由 。 图 中 己 标 明了 两 台 主机 的 MAC 地 址 、IP 地 址 、 网 关 IP 地 址 (也 就 
是 对 应 VLAN 接 口 耻 地 址 ) ， 以 及 三 层 交 换 机 的 MAC 地 址 。 


MAC 地 址 : MACS 
L3-SW 


局 
3 VLAN2 


IP: L111 
IP 地 址 : 1.1.1.2 
MAC 地 址 : MAC A 
网 关 : 1.1.1.1 


VLAN 3 
a ) 

ll i 

MAC 地 址 : MAC B 

网 关 : 2.1.1.1 


图 7-55 同一 交换 机 上 不 同 网 段 主 机 间 的 三 层 交 换 示例 


说 明 ”本 示例 中 虽然 划分 了 VLAN，, 但 是 在 下 面 的 数据 转发 流程 中 
我 们 并 没有 所 到 VLAN 标 记 ， 那 是 因为 在 本 示例 中 ， 通 信 双 方 主机 都 连 


接 到 同一 个 三 层 交 换 机 上 ， 端 口 类 型 均 为 Access 类 型 ， 发 送 和 接收 的 数 
据 幅 都 是 无 YLAN 标 记 的 。 在 下 市 介绍 的 示例 中 ， 在 数据 的 转发 过 程 中 
将 会 涉及 VLAN 标 记 问 题 。 


当 PC A 第 一 次 向 PC B 发 向 数据 包 时 ， 数 据 包 的 传输 流程 如 下 ( 假 
设 三 层 交 换 机 上 当前 还 未 建立 任何 硬件 转发 表 项 ) : 


1) PC A 首先 检查 出 目的 IP 地 址 2.1.1.2 (PC B) 与 自己 不 在 同一 网 
段 ， 觉 得 就 这 样 直 接 发 送 肯 定 不 行 ， 于 是 把 要 发 送 的 数据 包 先 缓存 起 
来 。 它 知道 这 个 数据 包 必须 经 过 网 关 来 转发 ， 所 以 先 查 看 一 下 自己 是 
已 经 知道 网 关 的 MAC 地 址 (也 就 是 在 PC A 主机 的 ARP 表 中 查看 是 否 有 
与 网 关 IP 地 址 对 应 的 MAC 地 址 表 项 ) 。 如 果 有 ， 则 直接 把 要 发 送 给 PC 
B 的 数据 包 在 封装 成 数据 帧 时 ， 把 < 目的 MAC 地 址 ?字段 的 值 设 为 网 关 的 
MAC 地 址 (也 就 是 三 层 交 换 机 的 MAC 地 址 MAC S， 交 换 机 上 各 端口 、 
各 VLAN 是 共享 一 个 或 多 个 MAC 地 址 的 ) 。 


2) 如 果 PC A 在 自己 的 ARP 表 中 没有 找到 网 关 MAC 地 址 ， 则 先 向 
网 关 发 出 (其 实 是 会 同 本 VLAN 内 所 有 节点 发 出 ) 一 个 ARP 广 播 请 求 报 
文 ， 以 获取 网 关 IP 地 址 1.1.1.1 所 对 应 的 MAC 地 址 。 此 ARP 请 求 报 文 的 源 
MAC 地 址 字段 是 PC A 的 MAC 地 址 MAC A， 目 的 MAC 地 址 因为 未 知 ， 
故 以 全 0 格式 填充 ， 源 IP 地 址 和 目的 IP 地 址 字段 分 别 填 上 PC A 的 IP 地 址 
(1.1.1.2) 和 网 关 的 IP 地 址 (1.1.1.1) 。 


ARP 请 求 报 文 向 下 传输 到 了 以 太 网 数据 链 路 层 后 被 再 次 封装 成 以 
太 网 帧 ， 以 太 网 帧 头 中 的 源 MAC 地 址 字段 值 仍 为 PC A 的 MAC 地 址 
MAC A， 目 的 MAC 地 址 字段 值 为 广播 MAC 地 址 FF-FF-FF-FF-FF-FF， 
帧 类 型 字段 填 上 ARP 的 协议 号 0x0806。 有 关 ARP 报 文 和 ARP 帧 格式 参见 


7.3 有 。 


3) 三 层 交 换 机 在 收 到 PC A 发 来 的 ARP 请 求 报 文 后 ， 检 查 请 求 报 文 
发 现 被 请 求 IP 地 址 (也 就 是 “目的 IP 地 址 ”) 是 自己 的 三 层 接口 了 地 址 ， 
于 是 向 PCA A 发 回 一 个 ARP 应 答 报 文 ， 并 将 对 应 的 三 层 接口 MAC 
(MAC S) 填充 在 应 答 报 文中 的 目的 MAC 地 址 字段 其 中 。 同 时 通过 对 
PC A 发 送 的 ARP 请 求 报 文 分 析 ， 把 PC A 的 IP 地 址 与 MAC 地 址 对 应 关系 
(1.1.1.2<==>MAC A) 记录 到 自己 的 ARP 表 中 去 ， 然 后 把 PC A 的 IP 
地 址 (作为 目的 IP 地 址 ) 、MAC 地 址 (作为 下 一 跳 MAC 地 址 ) ， 以 及 
与 交换 机 直接 相连 的 端口 号 等 信息 下 发 到 三 层 交 换 机 ASIC 必 片 中 的 三 
层 硬 件 转 发 表 。 此 时 在 三 层 硬 件 转发 表 中 就 有 了 第 一 个 转发 表 项 ， 即 
PC A 的 转发 表 项 。 


说 明 ”在 三 层 交换 机 中 ， 最 关键 的 就 是 它 有 一 个 专门 用 于 三 层 转 
发 的 三 层 硬 件 转发 表 ， 它 和 ARP 表 之 间 有 联系 ， 但 也 有 区 别 。ARP 表 
中 只 是 JP 地址 和 MAC 地 址 的 映射 关系， 不 包括 转发 出 口 ， 也 不 包括 对 
应 的 VLAN ID， 而 三 层 硬 件 转发 表 中 则 包括 了 全 部 这 些 ， 形 成 一 个 目 
的 IP 地 址 、VLAN ID、 端 口 和 下 一 跳 MAC 地 址 的 关系 表 项 。 因 为 在 进 


行 三 层 转发 时 ， 改 变 的 是 帧 封装 后 的 源 和 目的 MAC 地 址 这 两 个 字段 ， 
原来 输入 IP 包 中 的 目的 MAC 地 址 作为 转发 的 下 一 跳 MAC 地 址 ， 原 来 的 
源 MAC 地 址 改 为 三 层 交 换 机 自身 的 MAC 地 址 ， 源 和 目的 IP 地 址 都 不 变 
(因为 这 是 封装 在 帧 的 数据 部 分 |) 。 另 外 ， 三 层 转 发 表 是 存储 在 ASCI 
硬件 心 片上 的 ， 直 接 由 ASIC 心 片 调用 ， 而 ARP 表 存储 在 内 在 中 ， 由 

CPU 软件 调用 。 但 三 层 硬 件 转发 表 项 还 是 由 CPU 提供 的 。 


4) PC A 在 收 到 了 网关 的 ARP 应 答 报 文 后 ， 把 要 发 送 给 PC B 的 数据 包 
中 经 过 帧 封装 后 的 目的 MAC 地 址 修改 为 网 关 MAC 地 址 (MAC S1) ， 
其 它 不 变 ， 先 把 数据 包 发 给 网 关 (三 层 交 换 机 ) 。 


5) 三 层 交 换 机 在 收 到 这 个 数据 包 后 ， 因 为 目的 MAC 地 址 为 交换 机 
自己 的 MAC 地 址 ， 而 且 目 的 卫 地 址 和 源 耻 地 址 不 在 同一 网 段 ， 所 以 会 
直接 提交 到 负责 三 层 交 换 的 ASIC 必 片 ， 根 据 包 中 的 目的 耳 地 址 (PCB 
的 IP 地 址 2.1.1.2) 在 三 层 硬 件 转发 表 中 查看 有 无 对 应 表 项 ， 因 为 是 第 一 
次 通信 ， 所 以 结果 是 查找 失败 ， 于 是 将 数据 包 再 转送 到 CPU 中 进行 软 
件 路 由 处 理 。 


6) CPU 同 样 会 根据 包 中 的 目的 IP 地 址 查找 其 软件 路 由 表 ， 发 现 匹 
配 了 一 个 直 连 网 段 (PC B 对 应 的 网 段 ) ， 于 是 继续 查 在 ARP 表 中 查找 
对 应 的 MAC 地 址 项 。 同 样 和 站 由 于 是 第 一 次 查找 ， 所 以 仍然 得 找 失 败 。 
如 果 在 ARP 表 中 找到 了 对 应 的 MAC 地 址 ， 则 数据 可 以 直接 由 软件 路 由 
表 转 发 了 。 


7) 下 面 仍 以 在 ARP 表 中 也 没 找到 PC B 对 应 的 MAC 地 址 为 例 进行 介 
绍 。 此 时 三 层 交 换 机 CPU 会 在 PC B 所 在 网 段 的 AN 3 中 所 有 端口 发 送 一 
个 ARP 广 播 请 求 报 文 ， 查 找 目的 IP 地 址 为 2.1.1.2 所 对 应 MAC 地 址 。 报 文 
经 过 帧 封装 后 的 源 MAC 地 址 是 三 层 交 换 机 的 MAC 地 址 (MAC S) ， 目 
的 MAC 地 址 全 为 0， 源 IP 地 址 是 VLAN 3 网 段 的 网 关 IP 地 址 (2.1.1.1) ， 
目的 IP 地 址 是 PC B 的 IP 地 址 (2.1.1.2) 。 


8) PC B 在 收 到 三 层 交 换 机 CPU 发 送 的 ARP 请 求 报 文 后 ， 检 查 发 现 
被 请 求 的 IP 地 址 是 自己 的 IP 地 址 ， 于 是 发 送 一 个 ARP 应 答 报 文 ， 并 将 自 
己 的 MAC 地 址 (MAC B) 包含 在 其 中 。 同 时 ， 将 三 层 交换 机 上 VLAN 
3 网 段 的 网 天 IP 地 址 与 MAC 地 址 的 对 应 关系 (2.1.1.1<==>MACS) 记 
录 到 自己 的 ARP 表 中 去 。 


9) 三 层 交 换 机 CPU 在 收 到 PC B 的 ARP 应 答 报 文 后 ， 将 其 IP 地 址 和 
MAC 地 址 对 应 关系 (2.1.1.2<==>MAC B) 记录 到 自己 的 ARP 表 中 
去 ， 把 PC B 的 耳 地 址 、MAC 地 址 、 进 入 交换 机 的 端口 号 等 信息 下 发 到 
三 层 交 换 机 的 三 层 转发 中 。 此 时 转发 表 中 束 有 到 达 PC A 和 PC B 这 两 条 
对 应 的 表 项 了 。 


10) 三 层 交 换 机 CPU 根据 获得 的 PC B 的 MAC 地 址 和 端口 信息 ， 以 
及 软件 路 由 表 信 息 ， 把 由 PC A 发 来 的 IP 数 据 包 转 发 给 PC B， 这 样 就 完 
成 了 PC A 到 PC B 的 第 一 次 单 癌 通信 。 


由 于 芯片 内 部 的 三 层 引擎 中 已 经 保存 了 从 PC A 到 达 PC B 的 完整 转 
发 路 径 信息 ， 所 以 以 后 PC A 与 PC B 之 间 进 行 通信 ， 或 其 它 网 段 的 站 点 
想 要 与 PC A 或 PC B 进 行 通信 时 ， 三 层 交 换 机 的 ASIC 芯 片 就 会 直接 把 包 
从 对 应 的 三 层 硬件 转发 表 项 中 指定 的 端口 转发 出 去 ， 而 不 必 再 把 包 交 
给 CPU 进行 路 由 处 理 。 这 就 是 所 谓 的 “一 次 路 由 〈 指 通过 CPU 路 由 表 碍 
到 了 对 应 的 直 连 网 段 ) ， 多 次 交换 ”的 原理 ， 这 大 大 提高 了 转发 速度 。 


7.7.7 二 层 交 换 机 和 路 由 器 的 主要 区 别 


三 层 交 换 机 和 路 由 絮 都 具有 “路 由 ”功能 ， 看 起 来 好 像 功能 基本 一 
样 ， 其 实 两 者 无 论 从 结构 上 ， 还 是 从 应 用 环境 ， 两 者 部 存在 明显 区 别 
的 。 具 体 区 别 主 要 体现 在 以 下 几 个 方面 : 


(1) 三 层 功 能 实现 机 制 不 同 


有 许多 人 不 明 昌 ,它们 都 可 以 提供 三 层 路 由 功能 ， 既 然 有 了 路 由 
大 ， 为 什么 还 要 三 层 交 换 机 ， 或 者 反 过 来 问 ， 既 然 有 了 三 层 交 换 机 ， 
为 什么 还 要 路 由 右 ? 之 所 以 有 这 样 的 疑问 ， 其 实 是 不 明日 三 层 交 换 机 
和 路 由 响 的 三 层 功能 实现 机 制 的 原因 造成 的 。 


路 由 器 中 的 三 层 功 能 纯粹 依靠 所 安装 的 网 络 操 作 系 统 (如 Cisco 路 
由 需 中 的 IOS 系 统 ， 华 为 路 由 器 中 的 VRP 系 统 ，H3C 路 由 器 中 的 
Comware 系 统 ) ，CPU 通 过 调用 集成 在 这 些 操作 系统 的 路 由 协议 中 的 
路 由 表 来 实现 路 由 功能 。 所 有 经 过 路 由 器 的 数据 包 都 必须 通过 路 由 功 
能 来 实现 转发 。 


而 三 层 交 换 机 的 三 层 功 能 包括 两 个 方面 : 一 是 与 路 由 需 一 样 ， 它 
的 CPU 也 可 以 调用 所 安 逆 的 网 络 操作 系统 中 的 软件 路 由 融 功 能 ， 二 是 
它 像 二 层 交 换 机 一 样 也 有 专门 用 于 数据 交换 的 硬件 一 -ASIC 心 睫 ， 在 


它 里 面 同时 提供 了 二 层 交 换 模块 (含有 CAM 表 ) 和 三 层 交 换 引 擎 ， 其 
中 的 三 层 交 换 引 擎 中 建立 有 专门 用 于 三 改 交 换 的 三 讨 硬 件 转发 表 。 在 
三 层 交 换 机 中 ， 不 同 网 段 的 通信 采用 的 是 “一 次 路 由 ， 多 次 交换 ”机 制 
(新 型 的 交换 机 还 有 一 些 快速 交换 技术 ， 如 Cisco 的 CEF (Cisco 
Express Forwarding,Cisco 特 快 交换 ) ) ， 也 就 是 到 达 某 个 目的 主机 的 
数据 包 只 第 一 次 采用 路 由 方式 ， 在 建立 了 三 层 转 发 表 后 就 会 直接 通过 
三 层 转 发 表 进 行 二 层 转 发 了 ， 大 大 提高 了 转发 的 效率 。 


三 层 交 换 机 和 路 由 器 三 层 功能 实现 机 制 的 不 同 也 决定 了 它们 在 其 
他 许多 方面 的 不 同 。 


(2) 适用 环境 不 同 


三 层 交 换 机 是 由 二 层 交 换 机 发 展 而 来 的 ， 束 是 想 在 保留 二 层 交 换 
机 的 二 层 交 换 功 能 的 基础 上 表 提 供 三 层 路 由 功能 。 这 样 一 来 ， 三 层 交 
换 机 可 以 有 许多 用 于 连接 主机 及 各 类 其 他 设备 的 端口 ， 在 局 域 网 内 为 
各 下 点 提供 快速 的 二 层 数据 交换 。 因 为 三 层 交 换 机 在 其 ASIC 心 请 中 也 
有 像 二 层 交 换 机 一 样 的 硬件 CAM 表 。 同 时 它 又 可 以 为 局 域 网 中 不 同 
VLAN,， 或 者 不 同 子 网 提供 三 层 路 由 和 三 层 转 功能 ， 也 就 古 兼 具 二 层 
交换 机 和 路 由 右 的 双重 功能 ， 应 用 更 加 灵活 。 


或 许 你 马上 殊 又 会 问 ， 用 路 由 器 来 连接 局 域 网 中 的 不 同 VLAN 或 
子 网 不 就 行 了 ? 这 是 可 以 的 ,但 是 路 由 器 采用 的 钙 软 件 路 由 方式 ， 路 


由 性 能 比较 低下 ， 主 要 适用 于 低速 、 互 访 并 不 频繁 的 WAN 网 络 中 ， 而 
在 局 域 网 中 ， 不 同 VLAN 或 不 同 子 网 中 互 访 非常 频 紧 ， 低 速 的 路 由 性 
能 很 难 满足 实际 的 用 户 需 求 ， 特 别 是 在 较 大 的 局 域 网 中 。 三 层 交 换 机 
的 三 层 软 件 功能 是 基于 硬件 心 片 的 ， 三 层 转 发 性 能 更 高 ， 主 要 用 于 企 
业内 部 以 太 网 中 不 同 VLAN、 不 同 子 网 间 的 三 层 数据 交换 (一 般 不 提 
供 WAN 接 入 功能 ) ， 由 于 现在 其 一 般 是 采用 硬件 数据 交换 方式 ， 故 性 


能 更 高 。 


了 


(3) 多 协议 文 持 能 力 不 同 


尽管 路 由 亏 在 三 层 功 能 实现 效率 上 比 三 层 交 换 机 郑 些 ， 但 并 不 是 
说 二 层 交 换 机 束 可 以 全 面 取代 路 由 絮 。 因 为 三 层 交 换 机 目前 仅 文 持 IP 
网 络 层 协 议 ， 所 以 仅 可 适用 于 TCP/IP 网 络 ， 所 以 才 把 三 层 交 换 机 说 成 
征 卫 交换 机 “。 而 路 由 融 在 多 协议 文 持 方面 要 远 好 于 三 层 交 换 机 ， 因 为 
路 由 器 主要 应 用 于 WAN 中 ，WAN 中 的 网 络 类 型 可 能 非常 复杂 ， 所 以 
需要 文 持 更 多 的 网 络 层 协议 。 


(4) 路 由 能 力 不 同 


虽然 说 三 层 交 换 机 在 三 层 功能 实现 上 除了 路 由 功能 外 ， 还 有 效率 
更 高 的 硬件 三 层 发 功能 ， 但 仅 束 路 由 功能 来 说 ， 路 由 大 的 路 由 能 力 还 
征 要 远 好 过 三 层 交 换 机 的 ， 因 为 它 可 以 文 持 更 加 复杂 的 网 络 路 由 ， 可 
以 支持 更 大 的 路 由 表 项 ， 更 加 复杂 的 路 由 表 计 算 。 男 外 ， 由 于 三 层 交 


换 机 的 三 层 转发 功能 主要 依靠 ASIC 世 片 ， 它 是 硬件 ， 不 容易 升级 、 更 
新 ， 而 路 由 夯 的 路 由 功能 则 是 领先 软件 的 网 络 操作 系统 ， 更 容易 升 
双环 更 新 


综 上 所 述 ， 束 目前 来 说 三 层 交 换 机 和 路 由 万 可 以 说 是 各 有 优势 ， 
但 它们 的 主要 应 用 领域 各 不 相同 ， 三 层 交 换 机 主要 用 于 企业 IP 局 域 网 
中 不 同 VLAN 或 不 同 子 网 间 的 三 层 通信 ， 而 路 由 融 则 主要 用 于 WAN 中 
的 网 络 互 连 。 谁 也 不 能 完全 替代 谁 。 


第 8 章 ”了 地 址 和 子 网 


我 们 已 对 IPv4 和 IPv6 协 议 有 了 一 个 比较 全 面 的 了 解 ， 前 面 着 重 介 
绍 了 它们 各 目的 报 文 格式 、IPv4 报 文 封装 和 解 封装 ，IPv4 报 文 分 段 与 
重组 ， 以 及 IPv4 和 IPv6 协 议 复 中 主要 的 子 协 议 用 途 、 报 文 格式 等 。 


本 章 要 专门 介绍 在 卫 网 络 中 我 们 每 天 都 要 配置 的 IPv4 和 IPv6 地 
址 ， 其 中 主要 包括 IPv4 地 址 和 IPv6 地 址 的 表示 形式 和 分 类 ， 各 类 
IPv4、IPv6 地 址 结构 ， 以 及 在 进行 网 络 规划 和 设计 中 经 常 需 要 考虑 的 
IPv4 子 网 划分 与 聚合 方法 ，IPv6 地 址 的 自动 配置 过 程 。 这 些 都 是 非常 
基础 却 非常 重要 的 知识 和 技能 ， 不 要 说 网 络 职 业 人 士 ， 就 是 其 他 专业 
的 I 职业 人 员 都 必须 全 面 了 解 和 掌握 ， 因 为 无 论 是 在 一 般 计算 机 配 
置 ， 还 是 在 网 络 规划 、 设 计 与 组 建 过 程 中 ，IP 地 址 的 配置 与 管理 都 是 
必 不 可 少 的 。 


8.1 ”IPv4 地 址 


OSIRM 的 网 络 层 和 TCP/P 协 议 体系 结构 的 网 际 互 连 层 最 重要 的 一 
个 协议 就 是 IP 协 议 ， 目 前 正 处 于 IPvV4 和 IPv6 这 两 个 版 本 交接 、 过 渡 时 
期 ， 所 以 本 章 会 同时 对 这 两 种 版 本 的 人 P 地 址 及 相关 知识 进行 系统 介 
绍 。 本 市 先 介绍 目前 仍 为 主流 的 IPv4 地 址 。 


8.1.1 IPv4 地 址 基本 格式 


IPv4 使 用 32 位 (4 字 节 ) 地 址 ， 因 此 整个 地 址 空间 中 有 4 294 967 
296 〈23 ) 个 地 址 ， 也 就 是 近 43 亿 个 地 址 。 不 过 ， 其 中 一 些 地 址 是 为 
特殊 用 途 保留 的 ， 如 局 域 网 专用 地 址 〈 约 1800 万 个 地 址 ) 和 组 播 地 址 
( 约 2700 万 个 地 址 ) ， 这 样 一 来 可 直接 在 广域网 上 使 用 的 、 路 由 的 公 
网 IP 地 址 数量 就 更 加 少 了 。 


说 明 公 网 耳 地 址 是 指 可 以 在 广域网 上 直接 使 用 ， 直 接 被 路 由 
(也 就 是 可 以 被 指 路 径 查找 到 ) ， 并 需 向 IP 地 址 管理 机 构 申 请 、 注 
册 、 购 买 ， 且 全 球 唯一 (不 存在 多 个 用 户 拥有 、 使 用 相同 的 公 网 IP 地 
址 的 情况 ) 的 IPv4 地 址 。 打 个 比方 来 说 ， 公 网 JP 地 址 束 相 当 于 我 们 公 
民 的 号 份 证 号 ， 每 个 号 份 证 号 都 是 全 国 唯 一 ， 并 且 通 过 这 个 号 份 证 
号 ， 就 可 以 查 到 我 们 的 基本 信息 ， 找 到 我 们 。 公 网 地 址 直接 分 配给 
互联 网 上 的 主机 、 服 务 器 或 其 他 设备 ， 可 以 通过 它 在 全 球 范 围 内 找到 
对 应 的 主机 、 服 务 器 和 设备 。 如 各 大 企业 网 站 通常 都 是 直接 使 用 公 网 
IP 地 址 的 。 


与 公 网 IP 地 址 相对 应 的 目 然 是 私 网 JP 地 址 了 ， 义 称 专用 网 络 IP 地 
址 或 者 局 域 网 I P 地 址 。 私 网 IP 地 址 是 指 仅 可 以 在 各 用 户 目 己 的 局 域 网 
内 部 使 用 ， 且 不 同 用 户 可 以 重复 使 用 ， 无 须 同 IP 地 址 管理 机 构 申 请 、 
注册 ， 也 无 须 购买 的 IPv4 地 址 。 私 网 了 地 址 惑 相 当 于 我 们 企业 内 部 的 


员工 编号 ， 仅 在 企业 内 部 有 用 ， 不 能 通过 这 个 员工 编号 来 在 全 国 范围 
找到 我 们 。 企 业内 部 局 域 网 使 用 的 束 是 私 网 IP 地 址 ， 具 体 有 了 哪些 IP 地 
址 属于 私 网 IP 地 址 将 在 本 章 后 面 介 绍 。 


随 着 公 网 IP 地 址 不 断 被 分 配给 最 终 用 户 ，IPv4 地 址 枯竭 问题 也 在 
随 之 产生 。 虽 然 基 于 可 变 长 子 网 掩 码 (VLSM) 、 无 类 别 域 间 路 由 
(CIDR) 和 网 络 地 址 转换 (NAT) 的 地 址 结构 重 构 显 著 地 减少 了 地 址 
枯 竟 的 速度 ， 但 在 2011 年 2 月 3 日 ， 在 最 后 5 个 地 址 块 被 分 配给 5 个 区 域 
互联 网 注册 管理 机 构 之 后 ，IANA 的 主要 地 址 池 空 了 ， 所 以 现在 正在 积 
极 推 行 IPv6， 具 体 将 在 本 章 后 面 介绍 。 


IPv4 地 址 在 计算 机 内 部 是 以 二 进 制 形式 表示 的 ， 每 个 地 址 都 有 32 
位 ， 由 数字 0 和 1 构成 。 在 这 32 位 的 二 进 制 数 中 ， 其 实 每 个 8 位 之 间 并 没 
有 我 们 所 看 到 的 那个 用 来 分 隅 各 段 的 一 个 小 圆 点 ， 只 是 为 了 方便 我 们 
自己 阅读 ， 在 每 个 字 节 间 用 一 个 小 圆 点 分 隔 。 因 为 整个 了 地址 有 32 
位 ， 无 论 是 书写 还 是 记忆 都 不 方便 ， 于 是 我 们 在 日 党 的 卫 地 址 管理 中 
把 这 个 32 位 长 的 二 进 制 IP 地 址 分 段 转换 成 对 应 的 十 进 制 ， 在 每 个 字 市 
间 用 小 圆 点 分 隔 。 引 用 某 个 IPv4 地 址 时 ， 可 使 用 W.X.Y.Z 的 点 分 十 进 制 
表示 形式 ， 如 192.168.1.10 等 。 图 8-1 所 示 为 IPv4 地 址 的 基本 结构 ， 图 中 
的 W、X、Y、Z 每 个 都 代表 一 个 8 位 二 进 制 组 。 


W X Z 


< 一 一 3 位 一 > 


8-1 点 分 十 进 制 表 示 形 式 的 IPv4 地 址 


由 前 面 介 绍 的 数 制 转换 内 容 可 以 知道 ， 每 个 8 位 二 进 制 所 能 表示 的 
最 大 数 就 是 28 -1=256-1=255 〈 最 小 数 是 0) ， 所 以 IPv4 地 址 转换 成 十 进 
制 数 后 ， 每 段 8 位 二 进 制 组 的 取 值 范围 就 是 0~255。 因 为 JP 地址 在 计算 
机 中 是 以 二 进 制 表示 的 ，32 位 就 相当 于 4 字 节 ， 所 以 在 IPv4 协 议 数 据 报 
格式 〈 参 见 7.3.4 节 ) 中 ， 无 论 是 源 IP 地 址 字段 ， 还 是 目的 IP 地 址 字段 
都 占 4 字 节 的 。 


当然 ，IPv4 地 址 还 可 表示 成 八进制 、 十 六 进 制 ， 只 是 我 们 平时 不 
用 而 已 ， 具体 的 转换 方法 参见 本 书 第 1 章 相关 内 容 。 


8.1.2 ” 子 网 掩 人 码 


我 们 在 为 设备 配置 IP 地 址 时 ， 通 和 常 是 不 能 仅 配 置 IPv4 地 址 ， 而 必 
须 同时 配置 所 谓 的 子 网 掩 码 ， 如 图 8-2 所 示 。 那 么 子 网 掩 码 是 什么 ? 它 
又 有 什么 作用 ? 


| Internet 协议 版 本 4(TCP/IPv4) 属性 9 十 


人 


) 个) 自动 获得 I? 地 址 (0) 
| 局 使 用 下 而 站 地 址 (6) 
| | bto: 


子 网 摘 码 0D : 
默认 网 关 种 ) : 


| 自动 获得 Ds 服务 器 地 址 8) 

避 使 用 下 面 的 DNS 服务 器 地 址 E): 

首选 DRS 服务 器 灾 ) : 192 .166 . 1 .1 
备用 DRS 服务 性 以 ) : 


aE 0 


8-2 同时 的 IPv4 地 址 和 子 网 掩 码 


要 想 理解 什么 是 子 网 掩 码 ， 就 不 能 不 先 了 解 IPv4 地 址 的 构成 。 互 
联网 是 由 许多 小 型 网 络 构成 的 ， 每 个 网 络 上 都 有 许多 主机 ， 这 样 便 构 
成 了 一 个 有 层次 的 结构 。IPv4 地 址 在 设计 时 就 考虑 到 地 址 分 配 的 层次 
特点 ， 将 每 个 IP 地 址 都 分 割 成 网 络 ID 和 主机 ID 两 部 分 ， 以 便于 IPv4 地 
址 的 寻 址 操作 。 那 么 IPv4 地 址 的 网 络 ID 和 主机 ID 各 是 多 少 位 呢 ? 如 果 
不 指定 ， 在 寻 址 时 就 不 知道 对 应 IPv4 地 址 中 哪些 位 代表 网 络 ID、 哪 些 
代表 主机 ID， 这 就 需要 通过 这 里 所 说 的 子 网 掩 码 来 实现 了 。 


与 二 进 制 IPv4 地 址 相同 ， 子 网 掩 码 也 由 1 和 0 组 成 ， 且 长 度 也 是 32 
位 ， 我 们 也 可 以 把 它 分 成 网 络 ID 和 主机 ID 两 部 分 ， 且 各 自 的 长 度 与 
IPV4 地 址 的 网 络 ID 和 主机 ID 部 分 对 应 相等 。 但 子 网 掩 码 中 的 网 络 ID 部 
分 全 是 1，1 的 数目 等 于 网 络 ID 的 长 度 ; 主机 ID 部 分 全 是 0 表示 ，0 的 数 
目 等 于 主机 ID 的 长 度 。 如 图 8-3 所 示 的 是 一 个 网 络 ID 长 度 为 16 的 子 网 掩 
码 示例 。 这 样 做 的 目的 是 为 了 在 寻 址 过 程 中 使 子 网 掩 码 与 对 应 的 IPv4 
地 址 做 逻辑 与 运算 时 用 0 人 庶 住 IPv4 地 址 中 原 主机 ID 部 分 (因为 0 与 任何 
数 相 与 结果 都 是 0) ， 而 不 改变 原 网 络 ID 部 分 (因为 1 与 任何 数 相 与 的 
结果 都 不 改变 原来 的 值 ，， 这 样 就 一 来 就 可 以 很 容易 确定 对 应 目的 
IPV4 地 址 所 在 的 网 络 了 ， 确 定 了 网 络 ， 也 就 确定 了 主机 ， 因 为 在 IPv4 
地 址 中 除了 网 络 ID 部 分 就 是 主机 ID 部 分 。 


11111111 11111111 00000000 00000000 


网 络 ID 主机 ID 


8-3 ” 子 网 掩 码 示例 


于 网 掩 码 不 古 一 个 地 址 ， 但 是 可 以 确定 一 个 IPv4 地 址 中 的 哪 一 部 
分 是 网 络 ID， 哪 一 部 分 是 主机 ID， 和 连续 1 的 部 分 就 代表 网 络 ID ， 连 续 0 
的 部 分 代表 主机 ID。 子 网 掩 码 的 作用 束 是 获取 主机 IPv4 地 址 中 的 网 络 
地 址 信息 ， 用 于 区 别 主机 通信 不 同情 况 ， 选 择 不 同 路 由 。 了 于 网 掩 码 一 
旦 设置 ， 对 应 IPv4 地 址 中 的 网 络 ID 和 主机 ID 部 分 就 固定 了 。 


与 IPv4 地 址 一 样 ， 子 网 掩 码 也 可 以 转换 成 点 分 十 进 制 形式 。 根 据 
子 网 掩 码 格式 可 以 发 现 ， 子 网 掩 码 有 0.0.0.0; 255.0.0.0; 255.255.0.0; 
255.255.255.0; 255.255.255.255 五 种 ， 其 中 0.0.0.0 掩 码 代 表 任 意 网 络 的 
掩 码 ， 如 我 们 在 设置 默认 路 由 上 时， 不仅 IP 地 址 为 0.0.0.0， 子 网 掩 码 也 
为 0.0.0.0; A 类 地 址 的 默认 子 网 掩 码 为 255.0.0.0; B 类 地 址 的 默认 子 网 
掩 码 为 255.255.0.0; C 类 地 址 的 默认 子 网 掩 码 为 255.255.255.0; 而 
255.255.255.255 可 以 看 作 是 单一 主机 网 络 ， 代 表 这 个 网 络 就 这 一 个 
IPv4 地 址 ， 在 配置 ACL (访问 控制 列表 ) 时 ， 如 果 探 制 的 是 一 台 主 
机 ， 则 对 应 的 子 网 掩 码 也 为 255.255.255.255。 有 关 A、B、C 地 址 的 分 


类 将 在 下 节 介 绍 。 


8.1.3”IPv4 地 址 的 基本 分 类 


IPv4 地 址 共有 232 个 ， 最 初 把 一 个 IPv4 地 址 分 成 两 部 分 : “网 络 识别 
码 ?” 在 地 址 的 最 高 一 个 字 节 中 , “主机 识别 码 ” 在 剩 下 的 部 分 中 。 这 样 划 
分 的 话 ， 就 使 得 最 多 只 能 分 配给 256 个 网 络 ， 显 然 这 样 是 远 远 不 够 的 。 


为 了 克服 这 个 限制 ， 在 随后 出 现 的 分 类 网 络 中 ， 地 址 的 高 位 字 节 
被 重 定义 为 网 络 的 类 别 〈 即 网 络 ID) ， 共 五 个 : A、B、C、D 和 E。 
A、B 和 C 类 用 于 单 播 通信 中 设备 了 了 地址 分 配 ; D 类 属于 组 播 地 址 ， 用 于 
组 播 通信 ; E 类 是 保留 地 址 。 它 们 均 有 不 同 的 网 络 类 别 (也 就 是 网 络 
ID) 长 度 ， 剩 余部 分 用 来 识别 网 络 内 的 主机 〈 称 为 主机 ID) 。 网 络 ID 
用 来 确定 每 类 网 络 中 有 的 网 络 数 ， 而 主机 ID 用 来 确定 每 个 网 络 中 的 IP 
地 址 数 。 下 面 分 别 介绍 这 五 类 地 址 的 结构 。 


1.A 类 IPv4 地 址 


A 类 IPv4 地 址 结构 如 图 8-4 所 示 ， 其 中 网 络 D 占 用 最 高 一 个 字 方 ， 
也 就 是 第 一 个 二 进 制 8 位 组 ， 而 主机 ID 则 占用 剩余 三 个 字 节 ， 也 就 是 后 
面 的 三 个 二 进 制 8 位 组 。 


1 


< 一 网 络 ID 主 IID_ > 


图 8-4 A 类 地 址 的 结构 


在 分 类 中 规定 ，A 类 IPv4 地 址 中 网 络 ID 的 最 高 位 固定 为 0， 后 面 的 7 
位 可 变 。 这 样 一 来 ，A 类 网络 的 总 数 从 256 (28 ) 个 减少 到 128 (27) 
个 。 但 实际 上 可 用 的 只 有 126 个 ， 即 整个 IPv4 地 址 中 可 构建 126 个 A 类 网 
络 ， 因 为 网 络 ID 为 0 和 127 的 A 类 网 络 不 可 用 的 。 网 络 ID 全 为 0 的 地 址 为 
保留 地 址 ， 不 能 被 分 配 ; 而 网 络 ID 为 01111111 (相当 于 十 进 制 的 127) 
的 地 址 专用 本 地 环 路 测试 《也 就 是 通常 所 说 的 环 路 地 址 ) ， 也 是 不 能 
分 配 的 。 也 就 是 凡是 以 0 或 者 127 开 头 的 地 址 是 不 能 分 配给 节点 使 用 
的 。 


又 因为 A 类 IPv4 地 址 中 主机 ID 有 24 位 ， 所 以 可 用 的 主机 ID 数 ， 也 就 
是 可 以 每 个 A 类 网 络 中 拥有 的 IPv4 地 址 数 为 166 777 216 〈224 ) 。 但 主 
机 ID 全 为 0 的 地 址 为 网 络 地 址 ， 而 主机 ID 全 为 1 的 地 址 为 广播 地 址 ， 不 
能 分 配给 主机 使 用 ， 所 以 实际 上 可 用 的 地 址 数 为 166 777 214 (166 777 
216-2) 。A 类 网 络 中 可 以 构建 的 网 络 数 最 少 ， 但 每 个 网 络 中 拥有 的 地 
址 数 是 最 多 的 ， 也 就 是 可 以 构建 的 网 络 规模 最 大 ， 适 用 于 大 型 企业 和 
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ll 
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A 类 IPv4 地 址 的 子 网 掩 码 为 固定 的 255.0.0.0， 因 为 子 网 掩 码 就 是 网 
络 ID 部 分 全 为 1， 主 机 ID 部 分 全 为 0， 而 A 类 地 址 中 网 络 ID 部 分 就 是 最 


高 的 那个 字 节 。 


2.B 类 IPv4 地 址 


B 类 IPv4 地 址 结构 如 图 8-5 所 示 ， 其 网 络 ID 占用 最 高 的 前 两 个 字 
， 也 融 是 第 一 个 和 第 二 个 二 进 制 8 位 组 ， 而 主机 ID 则 占用 剩余 的 两 字 
， 也 就 古 后 面 两 个 二 进 制 8 位 组 。 


a 


< 网 络 ID 主机 ID 


dh 


图 。 8-5 B 类 地 址 的 结构 


B 类 IPv4 地 址 的 网 络 ID 的 最 高 两 位 固定 分 别 为 1、0， 后 面 的 14 位 可 
变 。 由 此 可 知 B 类 网 络 的 总 数 从 65 536 〈216 ， 也 可 写成 256x256) 减少 
到 16 384 (64x256) 个 ; B 类 IPv4 地 址 中 主机 ID 为 16 位 ， 所 以 可 用 的 主 
机 ID 数 ， 也 就 是 每 个 B 类 网 络 拥 有 的 IPv4 地 址 数 为 65 536 (216) 个 。 同 
样 因为 主机 ID 全 为 0 的 地 址 为 网 络 地 址 ， 而 主机 ID 全 为 1 的 地 址 为 广播 
地 址 ， 不 能 分 配给 主机 使 用 ， 所 以 实际 上 可 用 的 地 址 数 为 65 534 (65 
536-2) 。 


B 类 IPv4 地 址 的 子 网 掩 码 为 固定 的 255.255.0.0， 因 为 B 类 地 址 中 网 
络 ID 部 分 是 最 高 的 两 个 字 节 ， 每 个 字 节 均 为 8 个 连续 的 1， 转 换 成 十 进 


制 后 每 个 字 市 就 是 255 了 。 


3.C 类 IPv4 地 址 


C 类 IPv4 地 址 结构 如 图 8-6 所 示 ， 其 网 络 ID 占 用 最 高 的 前 三 个 字 
节 ， 也 就 是 第 一 个 、 第 二 个 和 第 三 个 二 进 制 8 位 组 ， 而 主机 ID 只 占用 了 
字 


= 
广 ， 也 就 是 只 有 最 后 一 个 二 进 制 8 位 组 。 


最 后 的 一 个 
01010 
< 网 络 ID >| |< 一 主机 ID 一 > 


图 。8-6 C 类 地 址 的 结构 


C 类 IPv4 地 址 的 网 络 ID 的 最 高 两 位 固定 分 别 为 1、1、0， 后 面 的 21 
位 可 变 。 由 此 得 知 C 类 网 络 总 数 从 166 777 216 (2%4 ， 也 可 写成 
256x256x256) 个 减少 到 2 097 152 (32x256x256) 个 。C 类 IPv4 地 址 中 
主机 ID 仅 为 8 位 ， 所 以 可 用 的 主机 ID 数 ， 也 就 是 每 个 C 类 网 络 拥有 的 
IPv4 地 址 数 为 256 (28 ) 个 。 同 样 因为 主机 ID 全 为 0 的 地 址 为 网 络 地 
址 ， 而 主机 ID 全 为 1 的 地 址 为 广播 地 址 ， 不 能 分 配给 主机 使 用 ， 所 以 实 
际 上 可 用 的 地 址 数 为 254 (256-2) 。 


C 类 单 播 地 址 的 子 网 掩 码 为 固定 的 255.255.255.0， 因 为 C 类 地 址 中 
网 络 ID 部 分 是 最 高 的 前 三 个 字 节 ， 每 个 字 节 均 为 8 个 连续 的 1， 转 换 成 


F 进 制 后 每 个 字 节 就 是 255 了 。 


表 8-1 总 结 了 A、B 和 C 三 类 IPv4 地 址 的 主要 特征 (如 图 8-1 所 示 ) 。 


每 个 网 络 的 主机 ID 数 
16 777 214 


4.D 类 IPv4 地 址 


D 类 IPv4 地 址 是 组 播 地 址 ， 用 于 IPv4 组 播 通信 中 。 通 过 组 播 IPv4 地 
址 ， 组 播 时 源 主机 (组 播 源 ， 只 需 发 送 一 份 数 据 ， 就 可 以 使 对 应 组 播 
组 (组 播 组 使 用 D 类 IPv4 地 址 标识 ) 中 的 一 个 或 多 个 主机 收 到 这 份 数 据 
的 副本 的 通信 方式 ， 但 只 有 组 播 组 内 的 主机 可 以 接收 该 数据 。 


PP 组 播 反 术 有 效 地 解决 了 单 点 发 送 多 点 接收 的 问题 ， 实 现 了 了 网 络 
中 点 到 多 点 的 高 效 数 据 传送 ， 能 够 大 量 节 约 网 络 融 宽 、 降 低 网 络 负 
载 。 还 可 以 利用 网 络 的 组 播 特性 方便 地 提供 一 些 新 的 增值 业务 ， 包 括 
在 线 直 播 、 网 络 电视 、 远 程 教育 、 远 程 医疗 、 网 络 电台 、 实 时 视频 会 
议 等 互联 网 的 信息 服务 领域 。 


D 类 IPv4 的 地 址 结构 如 图 8-7 所 示 ， 规 定 在 最 高 字 节 中 前 4 位 分 别 
定 为 1、1、1、0， 整 个 组 播 地 址 范围 为 224.0.0.0~239.255.255.255 。 


和 


图 8-7 D 类 IPv4 地 址 结构 


整个 组 播 IPv4 地 址 根据 不 同 的 应 用 环境 和 用 途 义 可 划分 为 预 留 组 
播 地 址 、 公 用 组 播 地 址 、 临 时 组 播 地 址 、 本 地 管理 组 播 地 址 四 大 类 。 


(1) 预 留 组 播 地 址 


预 留 组 播 地 址 (又 称 永久 组 播 地 址 ) 就 是 由 IANA 保留 不 分 配给 特 
定 用 户 使 用 ， 仅 为 公用 的 组 播 路 由 协议 分 配 使 用 的 组 播 地 址 ， 地 址 范 
围 为 224.0.0.0~224.0.0.255。 使 用 这 些 预 留 组 播 地 址 的 组 播 协议 包括 
IGMP (Internet 组 管理 协议 ) 、CGMP (Cisco 组 管理 协议 ) 、IGMP 
Snooping (IGMP 侦 听 ) 和 PIM (协议 无 关 组 播 ) 等 。 使 用 这 段 组 播 地 
址 的 耳 包 不 被 路 由 器 转发 。 


在 这 个 地 址 组 段 中 ，224.0.0.0 不 分 配 ; 224.0.0.1 分 配给 本 地 组 播 网 
络 所 有 文 持 组 播 的 主机 ，224.0.0.2 分 配给 本 地 组 播 网 络 中 的 所 有 组 播 路 
由 需 ; 224.0.0.4 分 配给 本 地 组 播 网 络 中 的 所 有 DVMRP 路 由 磊 ; 
224.0.0.5 分 配给 本 地 组 播 网 络 中 的 所 有 OSPF 路 由 人 种; 224.0.0.6 分 配给 
本 地 组 播 网 络 中 的 所 有 OSPF 指 定 路 由 器 (DR) ; 224.0.0.9 分 配给 本 地 
组 播 网 络 中 的 所 有 RIPv2 路 由 器 ; 224.0.0.10 分 配给 本 地 组 播 网 络 中 的 所 
有 IGRP 路 由 絮 ，224.0.0.13 分 配给 本 地 组 播 网 络 中 的 所 有 PIMvV2 路 由 
锋 ; 224.0.0.22 分 配给 本 地 组 播 网 络 中 的 所 有 IGMPvV3 路 由 馈 。 


(2) 公用 组 播 地 址 


公用 组 播 地 址 就 是 在 全 球 范围 内 可 以 直接 在 互联 网 上 使 用 的 组 播 
地 址 ， 就 像 前 面 介 绍 的 公 网 单 播 ITPv4 地 址 一 样 。 公 用 组 播 地 址 范围 为 
224.0.1.0~224.0.1.255， 也 是 由 IANA 为 提出 申请 并 付费 的 用 户 分 配 的 。 


(3) 临时 组 播 地 址 


临时 组 播 地 址 就 是 由 企业 用 户 在 本 企业 局 域 网 内 部 使 用 的 组 播 地 
址 ， 地 址 范围 为 224.0.2.0~238.255.255.255， 仅 在 本 地 局 域 网 内 有 限 ， 
就 像 前 面 介绍 的 局 域 网 IPv4 地 址 一 样 。 


(4) 本 地 管理 组 播 地 址 


本 地 管理 组 播 地 址 也 是 保留 使 用 的 ， 专 用 于 局 域 网 内 部 组 播 测 
试 ， 地 址 范围 为 239.0.0.0~239.255.255.255， 仅 在 特定 的 本 地 网 络 范围 
内 有 效 。 


当 网 络 层 收 到 组 播 数 据 报 文 时 ， 根 据 组 播 目 的 地 址 查找 组 播 转发 
表 ， 对 报 文 进行 转发 。 在 私 网 中 ， 组 播 是 不 需要 在 工作 站 上 配置 的 ， 
只 需要 在 网 络 中 的 路 由 器 或 者 支持 组 播 协议 的 三 层 交 换 机 上 进行 配 
置 。 私 网 工作 站 中 被 分 配 的 组 播 地 址 都 是 224.0.0.1， 就 像 环 路 地 址 
127.0.0.1 一 样 ， 无 须 另 外 配置 。 只 要 在 路 由 器 中 局 用 了 组 播 协议 后 就 可 
以 对 应 加 入 到 组 播 组 中 。 公 网 中 ， 工 作 站 组 播 地 址 选择 
224.0.1.0~238.255.255.255 范 围 中 的 一 个 即 可 。 


另外 ， 要 注意 的 是 ， 在 进行 组 播 通信 时 ， 在 数据 链 路 层 目 的 MAC 
地 址 字段 封装 的 也 是 组 播 MAC 地 址 。IANA 把 01:00:5E 开 头 的 以 太 网 
MAC 块 作为 组 播 地 址 对 应 的 二 层 组 播 MAC 地 址 。 组 播 MAC 地 址 的 范围 
是 01:00:5E:00:00:00~01:00:5E:7F:FF:FF 〈 前 24 位 为 MAC 头 ， 固 定 不 
变 ， 第 25 位 为 0) ， 并 要 求 将 IPv4 组 播 地 址 的 后 28 位 (因为 最 高 的 4 位 
是 固定 不 变 的 ) 映射 到 48 位 的 MAC 地 址 空间 中 。 


具体 的 映射 方法 是 将 组 播 IPv4 地 址 中 的 低 23 位 放 入 MAC 地 址 的 低 
23 位 ， 如 图 8-8 所 示 。 至 于 为 什么 要 映射 后 面 的 23 位 ， 原 因 束 在 于 根据 
IANA 给 出 组 播 MAC 地 址 段 是 前 3 字 市 (也 就 是 24 位 ) 来 标识 单位 或 者 
厂商 ， 只 有 后 面 24 位 来 和 IP 地 址 映射 ， 而 给 定 的 地 址 空间 后 3 字 节 的 最 
高 位 相同 ， 都 为 0， 那 么 给 定 的 MAC 地 址 段 内 只 有 23 位 了 ， 所 以 最 终 只 
能 丢弃 28 位 IPv4 地 址 中 的 前 5 位 ， 剩 下 的 23 位 和 MAC 的 23 位 相映 映 。 注 
意 ， 这 个 映射 无 须 手 动 进行 ， 在 路 由 器 启动 组 播 协议 ， 站 点 加 入 到 组 
播 组 后 束 会 自动 生成 。 


32 人 fyIP 地 址 | 1110XXXX | XXXXXXXX | XGO XXX 


5 位 未 映射 后 23f 下 


48 位 MAC 地 址 


00000001 | wa 01011110 Er me 


人 25 位 一 一 入 
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图 8-8 多 播 IFP 地 址 到 MAC 地 址 的 映射 


由 于 IPv4 多 播 地 址 的 后 28 位 中 只 有 23 位 被 映射 到 MAC 地 址 ， 这 样 
会 有 32 个 (23 ，IPv4 多 播 地 址 中 有 5 位 可 变 ) IP 多 播 地 址 映射 到 同一 
MAC 地 址 上 。 


5.E 类 IPv4 地 址 


E 类 IPv4 属 于 IANA 保留 地 址 ， 不 分 配给 用 户 使 用 ， 地 址 段 范围 为 
240.0.0.0~247.255.255.255， 其 特征 是 最 高 5 位 分 别 是 1、1、1、1、0， 
如 图 8-9 所 示 ， 也 就 是 有 27 位 是 可 变 的 。 


站 


图 8-9 E 类 IPv4 地 址 结构 


8.1.4 有 类 /无 类 IPv4 网 络 


通过 上 节 的 介绍 我 们 知道 ， 尽 管 已 针对 整个 IPv4 地 址 空间 进行 分 
类 ， 但 每 类 网 络 的 数量 对 于 全 球 用 户 数量 来 说 仍 非 常 之 少 ， 特 别 是 A 
类 网 络 才 区 区 的 126 个 。 之 所 以 会 出 现 这 种 现象 ， 原 因 就 在 于 每 类 网 络 
的 网 络 ID 部 分 (也 就 是 子 网 掩 码 部 分 ) 的 位 数 是 固定 不 变 的 ， 而 且 是 
字 节 的 整数 倍 ， 如 A 类 网 络 中 的 网 络 ID 部 分 占 1 字 节 (8 位 ) ，B 类 网 络 
中 的 网 络 ID 部 分 占 2 字 节 (16 位 ) 、C 类 网 络 中 的 网 络 ID 部 分 占 3 字 节 
(24 位 ) 。 


为 了 解决 这 种 可 用 网 络 数 太 少 的 问题 ， 同 时 提高 IP 地 址 有 有 效 利 
用 率 ， 于 是 出 现 了 一 种 称 为 VLSM (Variable Length Subnet Masking， 
可 变 长 子 网 掩 码 ) 的 技术 ， 该 拉 术 可 以 使 网 络 中 IPv4 地 址 的 子 网 掩 码 
所 占 位 数 不 是 固定 的 ， 如 子 网 掩 码 位 数 可 以 不 是 以 字 节 为 单位 的 整 
数 ， 如 12、13、14、25、26、28、 等 均 可 。 因 为 子 网 掩 码 位 数 不 固 定 
了 ， 也 就 不 能 再 依据 子 网 掩 码 来 进行 分 类 了 ， 上 所 以 采用 VLSM 后 形成 
的 网 络 称 为 无 类 网 络 ， 而 以 前 传统 的 A、B、C 类 网 络 则 相对 应 地 被 称 
为 有 类 网 络 或 标准 网 络 。 而 我 们 把 在 有 类 网 络 中 通过 YLSM 技 术 改变 
子 网 掩 码 长 度 而 划分 的 小 网 络 称 为 子 网 。 有 关子 网 的 划分 将 在 本 幕后 
面具 体 介 绍 ， 在 此 仅 介 绍 无 类 网 络 的 一 些 基 础 知识 。 


这 时 你 可 能 马上 会 问 ，VLSM 能 给 我 们 带 来 什么 好 处 ? 简单 地 说 
体现 在 三 个 方面 用 户 可 以 根据 网 络 规模 大 小 选择 拥有 适当 可 用 
IPv4 地 址 的 IPv4 地 址 段 ， 这 样 可 以 减少 IPV4 地 址 的 采 置 和 急 费 ， 降 低 
广播 风 骏 产生 的 可 能 ，Q 可 以 提高 路 由 效率 ; (3) 提 高 广域网 中 的 网 络 


安全 。 


举例 来 说 ， 先 说 在 局 域 网 中 。 假 设 你 公司 的 局 域 网 节点 数 为 1000 
个 左右 (也 就 需要 1000 个 左右 的 IPv4 地 址 ) ， 这 时 如 果 想 把 所 有 设备 
都 放 在 一 个 网 段 中 ， 这 样 各 设备 可 以 直接 进行 二 层 通信 ， 无 需 三 层 网 
络 设备 。 如 果 不 采 用 VLSM， 根 据 表 8-1 介 绍 的 三 类 网 络 类 型 所 对 应 拥 
有 的 IPv4 地 址 数 可 以 知道 ， 你 最 佳 的 选择 就 是 用 一 个 B 类 地 址 网 络 ， 
但 它 每 个 网 络 可 以 使 用 的 IPv4 地 址 总 数 达 到 了 65534 个 ， 相 对 你 只 有 
1000 个 节点 的 网 络 来 说 ， 显 然 是 大 材 小 用 了 ， 必 将 造成 有 绝 大 分 地 址 
在 你 的 网 络 中 根本 用 不 上 上， 白白 空 置 了 。 这 时 假设 你 的 公司 又 有 新 的 
局 域 网 要 组 建 ， 节 点 数 在 300 个 左右 ， 根 据 表 8-1 可 知 ， 你 同样 得 选 一 
个 B 类 地 址 段 来 进行 JP 地址 分 配 ， 但 这 时 用 不 上 的 地 址 数 就 更 多 了 。 
另外 ， 网 络 越 大 ， 也 就 是 广播 域 越 大 ， 上 自然 在 网 络 中 的 广播 流量 也 可 
能 越 大 ， 而 划分 子 网 后 ， 网 络 更 小 了 ， 广 播 域 也 更 小 了 ， 产 生 广 播 风 
暴 的 可 能 性 也 就 更 小 了 。 


或 许 你 会 说 ， 这 没什么 问题 啊 ， 反 正 局 域 网 IP 地 址 不 同 公司 是 可 
以 重复 使 用 的 ， 现 有 的 网 络 地 址 数量 一 个 公司 无 论 如 何 也 用 不 完 ， 而 


且 又 不 用 付费 。 这 的 确 是 这 样 的， 但 是 这 里 还 是 有 一 个 方面 你 没有 考 
虑 到 ， 那 殴 是 路 由 效率 的 问题 。 你 为 每 个 局 域 网 都 选择 一 个 标准 的 网 
络 ， 那 么 每 个 局 域 网 的 网 络 路 由 条 目 中 根据 不 同 网 络 进行 路 由 汇总 ， 

随 看 网 络 的 增 大 ， 路 由 条 目 必须 随 之 逐步 增多 ， 路 由 效率 目 然 下 降 

了 。 而 采用 VLSM 进 行 子 网 划分 后 路 由 是 可 以 汇总 的 ， 把 由 同一 标准 
网 络 划 分 的 多 个 子 网 路 由 条 目 汇总 成 一 条 标准 网 络 的 路 由 ， 可 以 使 路 
由 表 条 目 大 大 减少 ， 提 高 路 由 效率 。 


以 上 是 针对 局 域 网 专用 IPv4 地 址 来 说 的 ， 对 于 公 网 耳 地 址 来 说 ， 
采用 VLSM 所 带 来 的 好 处 就 更 明显 了 。 试 想 一 下 ， 如 果 仅 采用 标准 网 
络 的 分 类 ， 则 每 个 ISP 所 能 分 配给 企业 用 户 的 网 络 数 就 非常 有 限 了 ， 即 
使 是 最 多 的 C 类 网 络 ， 全 球 可 用 的 也 只 有 2 097 152 个 (其 中 还 有 65 536 
个 是 局 域 网 地 址 ) ， 这 显然 是 不 够 的 。 这 时 你 可 能 会 说 ， 这 是 C 类 网 
络 总 数 ， 但 是 每 个 C 类 网 络 中 还 有 254 个 地 址 啊 ， 两 者 相 乘 就 更 多 了 。 
在 此 且 先 不 说 一 个 个 来 分 配 是 否 够 用 ， 事 实 上 许多 企业 不 可 能 只 需要 
一 个 公 网 IPv4 地 址 ， 而 是 有 多 个 连续 的 IPv4 地 址 ， 为 多 个 互联 网 服务 


器 进行 分 配 。 


我 们 知道 ， 公 网 IP 地 址 是 在 互联 网 中 全 球 用 户 可 以 直接 访问 的 
(当然 这 要 求 用 户 已 在 公 网 中 使 用 这 个 地 址 ) ， 除 非 做 了 特别 的 限 
制 。 而 在 标准 网 络 中 ， 每 个 网 络 的 路 由 是 相同 的 ， 如 229.168.129.0/24 
这 个 网 段 的 路 由 条 目 中 就 是 包括 这 个 网 络 地 址 ， 凡 是 在 这 个 网 络 中 的 


地 址 均 可 通过 这 条 路 由 到 达 。 现 假设 A 公 司 购买 了 一 个 
227.126.128.10~227.126.128.20 的 C 类 公 网 地 址 段 ， 而 B 公 司 购买 了 一 个 
227.126.128.30~227.126.128.50 的 C 类 公 网 地 址 段 ， 它 们 所 购买 的 这 些 
公 网 地 址 均 用 于 一 个 为 互联 网 用 户 提供 服务 的 小 服务 器 网 络 中 。 


如 果 没 有 VLSM，A 公 司 和 B 公 司 的 局 域 网 均 只 能 通过 配置 
227.126.128.0/24 这 条 路 由 来 实现 内 部 局 域 网 与 服务 器 网 络 的 互通 。 但 
这 样 一 来 ， 如 果 没 有 其 他 限制 措施 ， 则 两 家 公司 的 这 条 路 由 都 可 能 到 
达 对 方 的 服务 硕 ， 这 显然 不 行 ， 很 不 安全 ， 也 不 便于 ISP 对 用 户 IPv4 地 
址 和 域名 服务 的 管理 。 但 如 果 为 每 个 用 户 分 配 整 个 网 络 的 地 址 段 ， 一 
方面 用 户 不 需要 ， 也 不 可 能 花 那 么 大 资金 来 购买 用 不 完 的 公 网 IPv4 地 
址 ， 男 一 方面 ISP 也 不 可 能 这 样 来 分 配 ， 因 为 事实 上 IPv4 地 址 资源 非常 
有 限 ， 到 了 有 钱 也 买 不 到 的 地 步 。 如 果 采 用 VSLM， 则 可 以 很 好 地 根 
据 用 户 实 际 需要 为 每 个 用 户 设 置 一 个 单独 的 子 网 ， 这 样 就 可 以 杜绝 不 
同 公司 中 公 网 地 址 网 络 的 不 安全 性 。 


对 于 地 址 数 是 否 够 用 的 问题 ， 相 信 不 用 我 过 多 解释 ， 全 球 有 那么 
多 企业 或 者 个 人 用 户 都 在 申请 购买 公 网 耻 地 址 ， 据 悉 目前 IPv4 可 用 的 
公 网 IP 地 址 已 全 部 分 配 完 ， 没 有 余 量 了 。 对 于 公 网 IPv4 地 址 说 ， 采 用 
VSLM 同 样 可 以 像 局 域 网 中 那样 提高 路 由 效率 ， 特 别 是 在 那些 大 型 的 
ISP 广 域 中 。 


8.1.5 网 络 地 址 、 主 机 地 址 和 广播 地 址 


在 一 些 考试 或 者 阅读 一 些 技术 资料 时 经 常见 到 网 络 地 址 、 主 机 地 
址 和 广播 地 址 这 几 个 术语 ， 那 么 它们 各 代表 什么 意义 呢 ? 


1. 网 络 地 址 、 主 机 地 址 、 广 播 地 址 的 定义 


网 络 地 址 站 用 来 标识 一 个 有 类 或 无 类 网 络 的 地 址 ， 是 对 应 网 络 或 
子 网 的 第 一 个 IPv4 地 址 ， 即 主机 ID 部 分 全 为 0 的 IPv4 地 址 ; 而 广播 地 址 
则 有 是 一 个 有 类 或 无 类 网 络 中 的 最 后 一 个 IPv4 地 址 ， 即 主机 ID 部 分 全 为 1 
的 IPv4 地 址 ， 可 通过 这 个 地 址 向 对 应 网 络 或 子 网 以 广播 方式 发 送 数 据 
包 (也 就 是 广播 通信 ) ， 让 本 地 网 络 或 子 网 的 所 有 节点 都 可 收 到 同一 
数据 包 。 


在 一 个 对 应 网 络 或 子 网 中 ， 除 了 网 络 地 址 和 广播 地 址 这 两 个 一 
头 、 一 尾 的 地 址 外 ， 中 间 其 他 的 所 有 地 址 都 是 主机 地 址 ， 它 是 可 直接 
分 配给 主机 使 用 的 IPv4 地 址 。 


如 在 192.168.1.0/24 网 络 中 《有 关 地 址 前 缀 表示 形式 将 在 下 节 介 
绍 ) ， 网 络 地 址 为 192.168.1.0/24， 广 播 地 址 为 192.168.1.255/24， 其 他 
254 个 IPv4 地 址 都 是 主机 地 址 。 如 192.168.1.0/26 这 样 一 个 子 网 中 ， 它 的 
网 络 地 址 为 192.168.1.0/26， 而 广播 地 址 为 192.168.1.63， 而 中 间 其 他 的 


62 个 IPv4 地 址 都 是 主机 地 址 。 有 关子 网 划分 的 方法 将 在 本 章 后 面 介 


绍 。 


说 明 ”我 们 也 经 常 听 到 单 播 、 组 播 、 广 播 这 三 个 术语 。 这 是 IPv4 
协议 根据 所 使 用 的 IPv4 地 址 通信 用 途 来 划分 的 三 种 方式 单 播 
(unicast) 是 指 一 人 台 源 IP 主 机 仪 与 一 人 台 目 的 IP 主 机 进行 通信 的 方式 。 
单 播 通信 中 所 使 用 的 IPv4 地 址 就 是 单 播 地 址 ， 在 A、B、C 三 类 地 址 中 
( 仅 指 IPv4) 除了 前 面 说 到 的 广播 地 址 ， 以 及 其 他 不 能 分 配给 主机 使 
用 或 者 保留 使 用 的 地 址 外 ， 其 他 的 全 是 单 播 地 址 ， 包 括 前 面 说 的 公 网 
IP 地 址 和 私 网 IP 地 址 。 


组 播 (Maulticast) 是 指 一 台 源 IP 主 机 同时 与 网 络 中 多 台 IP 主 机 进 
行 通信 的 方式 ， 又 称 多 播 。 组 播 通 信 所 用 的 IPv4 地 址 就 是 组 播 地 址 ， 
D 类 IPv4 地 址 就 是 组 播 地 址 。 通 过 这 类 IPv4 地 址 可 以 把 一 个 数据 包 发 送 


到 多 个 指定 的 节点 上 。 


广播 (broadcast) 是 指 一 台 源 IP 主 机 同时 与 本 地 网 络 或 子 网 中 所 
有 其 他 节点 进行 通信 的 方式 。 广 播 播 通信 所 用 的 IPv4 地 址 束 古 广播 地 
址 ， 束 是 指 本 世 介 绍 的 广播 地 址 。 


理解 网 络 地 址 和 广播 地 址 要 注意 以 下 两 个 方面 : 


1) 某 个 或 某 儿 个 8 位 组 值 为 0 或 者 255 的 IPv4 地 址 不 一 定 就 是 网 络 
地 址 或 广播 地 址 。 不 要 一 看 到 某 个 或 者 某 几 个 8 位 组 值 全 为 0 束 认 为 是 


网 络 地 址 ， 也 不 要 一 看 到 某 个 或 某 几 个 8 位 组 值 全 为 1 就 认为 是 广播 地 
址 ， 有 具体 还 是 要 看 主机 ID 部 分 是 否 全 为 0， 或 1。 如 1.1.0.0/8 这 个 地 址 
就 不 是 网 络 地 址 ， 因 为 它 是 一 个 标准 的 A 类 网 络 。 主 机 ID 部 分 应 该 是 
后 面 的 全 部 3 字 市 (24 位 ) ， 现 在 只 有 最 后 2 字 节 的 值 全 为 0， 而 第 二 个 
字 节 的 值 为 1。1.1.0.0/8 的 网 络 地 址 是 1.0.0.008。 同 样 ，1.1.1.255/8、 
1.1.255.255/8 也 不 是 广播 地 址 ， 原 因 同 上 ， 只 是 这 里 的 主机 ID 部 分 
(也 就 是 最 后 3 字 节 ， 共 24 位 ) 应 该 全 为 1 (每 个 字 节 转换 成 十 进 制 为 
255) ,但 这 里 只 有 最 后 2 字 节 的 值 全 为 1 。 


对 于 无 类 网 络 来 说 更 是 这 样 ， 因 为 在 一 个 无 类 网 络 中 多 个 C 类 或 B 
类 有 类 网 络 都 可 以 聚合 成 一 个 更 大 的 网 络 ， 其 中 就 可 能 包括 许多 某 些 8 
位 组 全 为 0 或 255 的 IPv4 地 址 。 


2) 网 络 地 址 和 广播 地 址 中 不 一 定 是 整个 8 位 组 的 值 为 0 或 255。 也 
不 是 所 有 网 络 地 址 的 主机 ID 都 是 整个 字 市 的 十 进 制 值 为 0%， 所 有 网 络 
地 址 的 主机 ID 都 是 整个 字 市 的 十 进 制 值 为 255。 这 仅 适 用 于 标准 的 有 
类 网 络 ， 因 为 有 类 网 络 中 ， 都 古 用 整个 字 市 来 划分 网 络 ID 和 主机 ID 
的 ， 但 在 无 类 网 络 中 ， 并 不 是 这 样 的 。 


在 无 类 网 络 中 ， 子 网 掩 码 长 度 是 可 变 的 ， 不 是 固定 的 多 少 个 子 市 
长 度 。 这 里 涉及 两 个 概念 ， 了 于 网 划分 和 子 网 察 合 。 了 于 网 划分 古 在 标准 
的 有 类 网 络 基础 上 ， 通 过 回 主 机 ID 部 分 借 位 变 成 网 络 ID 来 实现 的 ， 相 


肥 子 网 率 合 十 通过 向 网 络 ID 借 位 变 成 主机 ID 来 实现 的 。 具 体 的 子 网 划 
分 和 子 网 聚合 方法 将 在 本 章 后 面 介绍 


如 要 把 192.168.1.0/24 网 络 划 分 成 四 个 子 网 ， 它 就 是 通过 癌 “ 主 机 
ID” 借 2 位 来 实现 的 ， 这 4 个 子 网 分 别 是 : 192.168.1.0~192.168.1.63 
(192.168.1.0/26) 、192.168.1.64~192.168.1.127 (192.168.1.64/26) 
192.168.1.128~192.168.1.191 (192.168.1.128/26) 
192.168.1.192~192.168.1.255 (192.168.1.192/26) 。 它 们 都 有 自己 对 应 
的 如 下 “网 络 地 址 和 “广播 地 址 >”. 


口 192.168.1.0/26 子 网 的 网 络 地 址 是 192.168.1.0/26、 广 播 地 址 是 
192.168.1.63/26;: 


口 192.168.1.64/26 子 网 的 网 络 地 址 是 192.168.1.64/26， 广 播 地 址 是 
192.168.1.127/26; 


口 192.168.1.128/26 子 网 的 网 络 地 址 是 192.168.1.128/26， 广 播 地 址 
为 192.168.1.191/26; 


口 192.168.1.192/26 子 网 的 网 络 地 址 是 192.168.1.192/26， 广 播 地 址 
是 192.168.1.255/26 。 


由 此 可 见 ， 各 子 网 的 网 络 地 址 或 广播 地 址 并 不 是 整个 字 节 长 度 均 
为 0 或 1， 转 换 成 十 进 制 后 也 就是 不 一 定 是 0 或 者 255 了 。 


2. 广 播 地 址 类 型 


本 来 广播 地 址 只 有 一 种 ， 就 是 每 个 标准 有 类 网 络 中 所 说 的 最 后 那 
个 IPv4 地 址 ， 它 可 以 在 整个 标准 网 络 中 进行 广播 (注意 ， 路 由 器 是 不 
会 转发 广播 包 的 ) 。 但 自从 有 了 无 类 网 络 后 ， 根 据 其 广播 范围 的 大 
小 ，IPvV4 广 播 地 址 就 分 出 了 以 下 几 种 : 


(1) 网 络 广 播 地 址 


网 络 广播 地 址 是 传统 意义 上 的 广播 地 址 ， 也 束 是 标准 的 有 类 网 络 
中 的 广播 地 址 。 网 络 广播 地 址 可 以 将 数据 包 广 播发 送 到 本 地 有 类 网 络 
内 部 所 有 节点 上 。IPv4 路 由 亏 不 转发 目的 下 地 址 为 网 络 广播 地 址 的 广 
播 数据 包 ， 也 区 是 网 络 广播 包 只 能 在 一 个 本 地 网 络 内 部 广播 ， 不 能 被 
路 由 到 其 他 网 络 中 。 


网 络 广播 地 址 是 通过 将 有 类 IPv4 地 址 (A、B、C 三 类 ) 中 的 所 有 
主机 ID 部 分 全 部 设置 为 1 而 得 到 的 ， 也 就 是 每 个 主机 ID 的 8 位 组 均 为 
255。 例 如 ，151.110.0.0 是 一 个 有 类 别 地 址 的 B 类 地 址 ， 则 其 网 络 广播 
地 址 为 151.110.255.255。 


(2) 子 网 广播 地 址 


子 网 广播 地 址 是 针对 具体 子 网 的 广播 地 址 。 它 仅 可 以 将 数据 包 发 
送 到 相应 无 类 别 子 网 内 部 的 所 有 节点 上 。IPv4 路 由 需 也 不 转发 目的 IP 


地 址 为 子 网 广播 地 址 的 广播 数据 包 ， 也 吏 是 子 网 广播 包 只 能 在 一 个 子 
网 内 部 广播 ， 而 不 能 被 路 由 到 其 他 子 网 中 。 


子 网 广播 地 址 是 通过 将 无 类 别 地 址 的 主机 ID 部 分 全 部 设置 为 1 而 
得 到 的 ， 因 为 在 包含 主机 ID 的 8 位 组 中 还 包括 网 络 ID (严格 地 讲 是 子 
网 ID) ， 所 以 这 时 的 广播 地 址 中 主机 ID 所 对 应 的 8 位 组 值 就 不 一 定 是 
255 了 “。 例 如 ，192.168.1.0/26 这 个 子 网 的 广播 地 址 是 192.168.1.63， 而 
不 是 192.168.1.255。 


(3) 全 子 网 定向 广播 


全 子 网 定 同 广播 地 址 是 针对 一 个 标准 有 类 了 网络 划 分 的 子 网 而 言 
的 ， 等 于 这 个 标准 网 络 的 广播 地 址 。 它 可 以 将 数据 包 以 广播 方式 发 送 
到 由 该 标准 网 络 划分 的 所 有 子 网 节点 上 。 如 前 面 所 说 的 192.168.1.0/24 
标准 有 类 网 络 通过 加 主机 ID 借 两 位 的 方法 划分 成 192.168.1.0/26、 
192.168.1.64/26、192.168.1.128/26、192.168.1.192/26 这 四 个 子 网 ， 原 
来 192.168.1.0/24 标 准 有 类 网 络 的 广播 地 址 192.168.1.255 就 是 这 四 个 子 
网 的 全 定向 广播 地 址 。 这 类 广播 包 可 以 在 以 它 划 分 的 所 有 子 网 上 广 
播 ， 也 就 是 IPv4 路 由 器 可 以 转发 这 类 广播 包 。 


(4) 有 限 广 播 


有 限 广 播 地 址 是 通过 将 IPv4 地 址 的 32 个 位 全 部 设置 为 1 
(255.255.255.255) 而 形成 的 。 在 本 地 网 络 ID 未 知 的 情况 下 (如 采用 


DHCP 服 务 自动 分 配 耳 地 址 的 客户 端 ) ， 可 以 使 用 有 限 广 播 地 址 来 进 
行 本 地 网 络 或 子 网 内 部 所 有 节点 传送 。IPv4 节 点 通常 仅 在 自动 化 配置 
过 程 (例如 启动 协议 (BOOTP) 或 DHCP) 中 使 用 有 限 广播 地 址 ， 如 
DHCP 服 务 ，DHCP 和 客户 端 发 出 的 请 求 报 文 和 DHCP 服 务 器 返回 的 应 答 


报 文 都 是 以 255.255.255.255 作 为 目的 地 址 的 ， 因 为 那 时 DHCP 客 户 端 还 
没有 分 配 到 具体 的 IP 地 址 。 


8.1.6 IPv4 地 址 前 缀 表示 形式 


通过 上 区 的 学 习 我 们 已 经 知道 ， 仅 给 出 一 个 IPv4 地 址 ， 我 们 仍然 
无 法 知道 它 所 在 的 网 络 ， 也 吏 无 法 仅 通 过 这 个 站 地 址 来 进行 寻 址 和 路 
由 了 。 


传统 的 IPv4 地 址 表示 方法 是 在 给 出 具体 的 IPV4 地 址 的 同时 给 出 它 
所 对 应 的 子 网 掩 码 ， 如 192.168.1.10、255.255.255.0 等 。 这 也 是 我 们 在 
为 方 点 配置 IP 地 址 的 同时 要 配置 子 网 掩 码 的 原因 。 但 在 日 常 书写 时 ， 
这 样 显然 比较 麻烦 ， 因 为 IPv4 地 址 和 子 网 掩 码 都 有 32 人 位， 转换 成 十 进 
制 后 仍然 各 有 四 段 ， 比 较 长 。 


为 了 能 更 加 简便 地 书写 ， 采 取 了 一 种 比较 简单 的 地 址 前 缀 表示 形 
式 ， 就 是 在 一 个 IPv4 地 址 (可 以 是 网 络 地 址 ， 也 可 以 是 主机 地 址 ) 后 
面 先 加 上 一 个 斜 枉 VY) ， 然 后 在 这 个 和 斜 杠 后 面 直接 写 出 该 地 址 所 在 网 
络 的 网 络 ID， 或 者 子 网 掩 码 长 度 ， 因 为 网 络 ID 长 度 决 定 了 具体 IPv4 地 
址 所 属 的 网 络 。 如 192.168.1.10/24 代 表 的 是 一 个 标准 的 C 类 网 络 IPv4 地 
址 ， 而 10.1.0.10/8 则 代表 了 一 个 标准 的 A 类 网 络 IPv4 地 址 。 


当然 ， 这 种 表示 方式 主要 还 不 是 为 了 标识 标准 的 有 类 网 络 ， 因 为 
标准 的 有 类 网 络 中 ， 各 类 网 络 的 网 络 ID 长 度 和 地 址 范围 都 是 固定 的 ， 
一 看 具体 的 IPv4 地 址 中 第 一 个 8 位 组 所 属 的 取 值 段 范 围 束 知道 属于 哪 类 


网 络 ， 及 所 对 应 的 网 络 ID 长 度 了 ， 根 本 不 用 标识 。 如 A 类 IPv4 地 址 第 
一 个 8 位 组 取 值 的 地 址 范围 为 1~126， 网 络 ID 长 度 固定 为 8 位 ;，B 类 IPv4 
地 址 第 一 个 8 位 组 取信 的 地 址 范围 为 128~191， 网 络 ID 长 度 固 定 为 16 

位 ; C 类 IPv4 地 址 第 一 个 8 位 组 取 值 的 地 址 范围 为 192~223， 网 络 ID 长 
度 固定 为 24 位 。 


其 实 无 论 是 网 络 ID， 还 子 网 掩 码 长 度 ， 最 大 的 意义 还 是 针对 无 类 
网 络 而 言 ， 因 为 这 时 它们 是 可 变 的， 也 没有 A、B、C 这 样 的 分 类 了 ， 
无 论 第 一 个 8 位 组 属于 哪个 取 值 范围 ， 都 可 以 有 各 种 网 络 ID、 了 于 网 掩 
码 长 度 。 如 有 1.1.10.20/26 这 样 的 地 址 ， 也 可 以 有 192.168.1.10/8 这 样 的 
地 址 ， 前 者 通过 子 网 划分 得 到 ， 而 后 者 可 以 通过 子 网 聚合 得 到 。 


与 采用 子 网 掩 码 表示 形式 一 样 ， 从 一 个 IPv4 地 址 表示 形式 中 的 地 
址 前 级 值 可 以 看 出 这 个 IPv4 地 址 所 在 的 网 络 或 子 网 ， 以 及 这 个 网 络 和 
子 网 的 地 址 范围 。 如 从 131.107.0.0/18 这 个 地 址 中 可 知 它 所 对 应 的 网 络 
中 有 18 位 属于 网 络 ID 部 分 ， 有 14 位 属于 主机 ID 部 分 ， 可 分 配给 主机 的 
IPV4 地 址 数 就 是 214 -2=16382 。 


8.1.7 ” 几 种 特殊 的 IPv4 地 址 


在 我 们 平时 进行 IPv4 地 址 配置 和 管理 时 ， 经 常 遇 到 这 么 几 种 特殊 
的 IPv4 地 址 ， 其 中 一 种 最 重要 的 IPv4 地 址 惑 是 私 网 耳 地 址 ， 也 就 是 通 
常 所 说 的 局 域 网 IP 地 址 或 者 专用 网 络 IP 地 址 。 还 有 像 以 9、127、169 开 
头 的 IPv4 地 址 。 本 市 将 做 一 个 集中 介绍 。 


1. 私 网 IP 地 址 


为 了 提高 IPv4 地 址 的 重复 利用 率 ， 在 设计 IPv4 地 址 时 吏 专 门 在 前 
面 介绍 的 A、B、C 这 类 IPv4 地 址 中 各 目 划 分 了 一 段 专用 于 各 组 织 局 域 
网 内 部 的 地 址 段 ， 这 就 是 我 们 前 面 所 说 的 私 网 IP 地 址 (又 称 局 域 网 专 
用 IP 地 址 或 者 专用 网 络 地 址 ; 。 私 网 IPv4 地 址 在 不 同 公司 内 部 的 局 域 
网 中 是 可 以 重复 使 用 的 ， 且 无 须 向 IP 地 址 管理 机 构 申 请 、 注 册 和 购买 
的 。 在 A、B、C 类 地 址 中 各 目 划 分 的 局 域 网 专用 地 址 段 如 下 。 


(1) 10.0.0.0/8 (10.0.0.0，255.0.0.0) 


在 A 类 地 址 中 ， 局 域 网 内 部 节点 可 以 使 用 10.0.0.1~10.255.255.254 
范围 内 有 效 单 播 ITPv4 地 址 。 如 果 用 地 址 前 组 表示 方式 ， 则 为 
10.0.0.0/8。 在 这 样 一 个 地 址 空间 中 有 24 个 主机 ID 位 ， 相 当 于 最 多 可 以 


有 224 (16 777 216) 个 IP 地 址 (包括 了 网 络 地 址 和 广播 地 址 ) ， 满 足 
了 几乎 所 有 大 型 规模 局 域 网 对 IP 地 址 的 需求 。 


(2) 172.16.0.0/12 (172.16.0.0，255.240.0.0) 


在 B 类 地 址 中 ， 局 域 网 内 部 节点 可 以 使 用 
172.16.0.1~172.31.255.254 范 围 内 的 有 效 IPv4 单 播 地 址 。 如 采用 地 址 前 
组 表示 方式 ， 则 为 172.16.0.0/12。 针 对 具体 的 网 络 ， 仍 是 B 类 网 络 中 所 
限制 的 16 位 主机 ID 个 数 ， 相 当 于 最 多 可 有 21 (65 536) 个 IP 地 址 ( 包 
括 了 网 络 地 址 和 广播 地 址 ) ， 满 足 了 几乎 所 有 中 等 规模 局 域 网 对 IP 地 
址 的 需求 。 


(3) 192.168.0.0/16 〈192.168.0.0，255.255.0.0) 


对 于 数量 最 多 的 小 型 局 域 网 ， 其 内 部 万 点 可 以 使 用 C 类 地 址 中 的 
192.168.0.1~192.168.255.254 范 围 内 的 有 效 IPv4 单 播 地 址 。 如 果 用 地 址 
前 缀 表示 ， 则 为 192.168.0.0/16。 针 对 具体 的 网 络 ， 仍 是 C 类 网 络 中 所 
限制 的 8 位 主机 ID 个 数 ， 相 当 于 最 多 可 有 28 (256) 个 IP 地 址 (包括 网 
络 地 址 和 广播 地 址 ) ,满足 了 大 多 数 小 型 规模 局 域 网 对 IP 地 址 的 需 
求 。 


因为 ICANN 永 远 不 会 把 专用 地 址 空间 内 的 IPv4 地 址 分 配给 一 个 连 
接 到 互联 网 的 组 织 ， 所 以 互联 网 路 由 器 中 也 永远 不 会 包含 指 疝 专 用 地 
址 的 路 由 。 您 也 无 法 通过 互联 网 连接 到 一 个 专用 地 址 。 正 因为 如 此 ， 


使 用 私 网 IPv4 地 址 的 主机 必须 将 其 互联 网 通信 和 量 请 求 发 送 到 一 个 有 效 
公用 地 址 的 应 用 层 网 关 〈 例 如 一 个 代理 服务 器 ) ， 或 者 通过 一 个 网 络 
地 址 转换 (NAT) 设备 将 此 专用 地 址 转换 成 一 个 有 效 的 公 网 IPv4 地 址 
再 与 互联 网 连接 。 


2.169 开 头 的 IPv4 地 址 


在 运行 Windows Server 2003 或 Windows XP 的 操作 系统 中 ， 如 果 你 
采用 的 是 自动 耻 地 址 分 配方 式 ， 但 本 地 网 络 中 又 没有 部 署 用 于 自动 TP 
地 址 分 配 的 DHCP 服 务 器 ， 则 这 些 系统 主机 束 会 目 动 获得 一 个 以 169 开 
头 的 耳 地 址 。 这 就 是 所 谓 的 目 动 专用 也 地址， 其 地 址 范围 包括 一 个 B 类 
地 址 段 一 169.254.0.0/116， 子 网 掩 码 为 255.255.0.0。 


3.127.0.0.1 地 址 


我 们 在 配置 网 络 设备 或 者 进行 系统 主机 测试 时 ， 经 常用 到 
127.0.0.1 这 个 地 址 。 它 不 能 分 配给 主机 用 ， 但 它 却 可 以 用 来 进行 各 种 
地 址 管理 操作 ， 如 Ping 操 作 。 其 实 这 个 地 址 有 个 专门 的 名 称 ， 即 环 回 
地 址 (Loopback Address) ， 是 主机 卫 堆 栈 内 部 的 IPv4 地 址 ， 主 要 用 于 
网 络 软件 测试 以 及 本 地 机 进程 间 通信 ， 在 卫 网 络 中 用 来 测试 主机 
TCP/IP 协 议 是 否 工作 正常 。 无 论 什么 程序 ， 一 旦 使 用 回环 地 址 发 送 数 
据 ， 协 议 软 件 立 即 返 回 ， 不 进行 任何 网 络 传输 ， 所 以 执行 Ping 操 作 也 


只 在 本 机 上 进行 环 路 测试 ， 用 来 检测 网 卡 是 否 工作 正常 〈 主 要 受 操作 
系统 中 通信 协议 和 驳 动 程序 安 半 是 否 正确 影响 ) 。 


4.0.0.0.0 地 址 


严格 说 来 ，0.0.0.0 不 是 一 个 真正 意义 上 的 耻 地 址 ， 因 为 我 们 在 介 
绍 IPv4 地 址 的 分 类 时 束 说 到 ， 第 一 个 8 位 组 的 值 不 能 为 0。 但 在 实际 的 
设备 配置 和 网 络 中 确实 又 要 用 到 这 样 一 个 IPv4 地 址 。 其 实 它 不 是 特 指 
某 个 IPv4 地 址 ， 在 不 同 的 情形 中 使 用 它 有 不 同 的 侣 义 。 如 我 们 在 配置 
默认 路 由 时 就 使 用 了 0.0.0.0 这 个 IPv4 地 址 ， 它 是 代表 所 有 不 清楚 路 由 
的 目的 主机 和 目的 网 络 。 这 里 的 “不 清楚 ?是 指 在 本 机 的 路 由 表 里 没有 
特定 路 由 表 项 指明 如 何 到 达 这 些 主机 或 网 络 。 在 网 络 配置 中 ，0.0.0.0 
又 代表 整个 网 络 ， 即 网 络 中 的 所 有 主机 。 


8.2 TIPv4 子 网 划分 与 聚合 


在 本 章 前 面 已 说 到 ， 为 了 解决 ITPv4 的 不 足 ， 提 高 网 络 划分 的 灵活 
性 ， 诞 生 了 两 种 非常 重要 的 技术 ， 那 就 是 VYLSM (可 变 长 子 网 掩 码 ) 
和 CIDR (无 类 别 域 间 路 由 ) ， 把 传统 的 标准 IPv4 有 类 网 络 演变 成 一 个 
更 为 高 效 、 更 为 实用 的 无 类 网 络 。VLSM 用 于 IPv4 子 网 的 划分 ， 世 就 
是 把 一 个 大 的 网 络 划 分 成 多 个 小 的 子 网 ; 而 CIDR 则 用 于 IPv4 子 网 的 聚 
合 ， 当 然 主要 是 指 路 由 方面 的 聚合 ， 也 就 是 路 由 汇总 。 通 过 CIDR 可 以 
把 多 个 小 的 子 网 路 由 条 目 汇总 成 一 个 大 网 络 的 路 由 条 目 ， 以 减少 路 由 
器 中 路 由 条 目的 数量 ， 提 高 路 由 效率 。 本 节 将 分 别 对 这 两 种 技术 和 实 
现 方法 进行 具体 介绍 。 


8.2.1 VLSM 子 网 划分 的 基本 思想 


子 网 这 个 概念 其 实 是 在 有 了 VLSM 技 术 后 才 有 的 ， 原 来 的 标准 网 
络 中 不 存在 子 网 的 概念 ， 因 为 那 时 每 个 标准 网 络 都 相互 独立 ， 互 不 包 
舍 。 本 下 将 具体 介绍 一 下 VLSM 子 网 划分 的 实现 机 制 和 两 种 非常 简单 
的 划分 方法 。 


通过 VLSM 实 现 子 网 划分 的 基本 思想 很 简单 ， 就 是 把 原来 标准 网 
络 IPv4 地 址 中 的 网 络 ID 部 分 向 主机 ID 部 分 借 位 ， 把 一 部 分 原来 属于 主 


机 ID 部 分 的 位 变 成 网 络 了 的 一 部 分 (通常 称 为 “ 子 网 ID”) ， 如 图 8-10 
所 示 。 原来 的 网 络 ID+ 子 网 ID= 新 网 络 ID， 子 网 ID 长 度 决 定 了 可 以 划分 
子 网 的 数量 。 


主机 ID 
一 


新 网 络 ID 新 主机 ID 


8-10 VLSM 问 “主机 ID” 借 位 示例 


因为 每 一 位 都 可 以 有 0 或 1 这 两 个 值 的 两 种 选择 ， 所 以 VLSM 可 以 
划分 的 子 网 数 是 22 个 An 为 子 网 ID 位 数 ， 也 就 是 向 原来 主机 ID 借 的 位 
数 ) ， 如 借 一 位 可 划分 成 2 个 子 网 ， 借 两 位 则 可 划分 成 4 个 子 网 ， 借 三 
位 则 可 以 划分 成 8 个 子 网 ， 以 此 类 推 。 不 能 划分 成 其 他 数量 子 网 ， 如 不 
能 把 一 个 网 络 仅 划分 成 3、5、6、7、9 之 类 个 数 的 子 网 。 但 因为 由 同一 
个 标准 网 络 划分 出 来 的 每 个 子 网 的 子 网 ID 长 度 一 样 ， 这 束 决 定 所 划分 


出 来 的 各 子 网 新 的 网 络 ID 长 度 也 一 样 ， 所 以 各 子 网 的 子 网 掩 码 也 一 
样 。 这 点 要 特别 注意 。 


这 样 一 来 ， 主 机 ID 部 分 的 长 度 变 小 了 ， 也 就 是 对 应 网 络 中 所 拥有 
的 IPv4 地 址 数 减 少 了 。 当 然 VLSM 的 主要 作用 不 是 用 来 减 小 网 络 ， 更 
关键 是 它 可 以 非常 灵活 地 依据 实际 所 需 的 地 址 数 来 调整 所 划分 的 子 网 
大 小 。 如 原来 一 个 标准 的 C 类 网 络 中 有 254 个 可 以 分 配给 节点 的 地 址 ， 
现在 公司 中 有 6 个 部 门 ， 每 个 部 门 的 人 数 不 超 过 30 人 ， 现 在 想 为 每 个 部 
门 分 别 配置 一 个 子 网 。 如 果 没 有 VLSM， 则 需要 用 6 个 C 类 标准 网 络 。 
而 有 了 VLSM 后 ， 仅 用 一 个 C 类 网 络 就 可 以 划分 出 所 需 的 6 个 子 网 ， 而 
且 每 个 子 网 中 可 用 的 IPv4 地 址 更 贴近 各 部 门 的 实际 需求 。 这 样 就 大 大 
提高 了 IPV4 的 利用 率 ， 同 时 更 便于 网 络 管理 ， 毕 况 这 些 部 门 子 网 属于 
同一 个 大 的 C 类 网 络 。 可 以 通过 路 由 汇总 功能 提高 路 由 效率 ， 这 对 于 
ISP 来 说 非常 有 用 ， 因 为 可 以 大 大 市 省 所 需 的 公 网 JP 地 址 数 。 


经 验 之 谈 VLSM 只 能 划分 相同 大 小 的 子 网 ， 也 整 古 一 个 网 络 划 
分 了 子 网 后 ， 各 子 网 的 IPv4 地 址 数 古 相同 的 。 要 想 使 各 子 网 大 小 不 一 
样 ， 则 必须 同时 绪 合 CIDR 技 术 ， 把 其 中 一 些 子 网 再 聚合 成 一 些 稍 大 坚 
的 子 网 。 另 外 ， 子 网 还 可 以 进一步 划分 成 更 小 的 子 网 ， 这 束 是 多 级 子 
网 划分 。 具 体 划 分 方法 将 在 下 市 通过 具体 的 示例 进行 介绍 。 


有 了 VLSM， 原 来 标准 网 络 中 的 分 类 (如 A、B、C 类 ) 方法 就 没 
有 太 大 实际 意义 了 ， 因 为 现在 在 网 络 IPv4 地 址 规划 中 都 会 考虑 使 用 


VLSM 子 网 划分 方法 。 原 来 标准 网 络 中 网 络 ID 和 主机 ID 部 分 都 是 固定 
不 变 的， 而 且 是 整 字 节 长 度 ， 每 一 类 网 络 有 它 特 定 的 子 网 掩 码 。 而 重 
新 划分 子 网 后 ，IPv4 地 址 的 网 络 ID 和 主机 ID 部 分 都 是 可 变 长 度 的 ， 子 
网 掩 码 也 不 再 限定 于 某 一 类 网 络 之 中 ， 也 就 是 同样 一 个 子 网 掩 码 (如 
原来 C 类 网 络 中 的 255.255.255.0) 可 以 应 用 于 原来 各 类 网 络 中 。 


VLSM 的 设计 目的 束 古 想 在 每 个 了 于 网 上 你 留 足 够 的 主机 数 的 同 
时 ， 把 一 个 标准 的 有 类 网 络 分 成 多 个 无 类 别 的 子 网 ， 提 高 原来 标准 网 
络 中 IPv4 地 址 的 有 效 利用 率 ， 也 提高 了 网 络 组 建 时 IPv4 规 划 的 灵活 
性 ， 因 为 这 样 划分 后 ， 虽 然 各 子 网 仍 在 一 个 大 的 标准 网 络 之 中 ， 但 彼 
此 仍 是 二 层 隅 离 ， 必 须 通过 三 层 才 可 以 实现 互通 ， 这 样 殉 满 足 了 许多 
企业 用 户 不 同 部 门 网 络 隔离 的 需要 。 如 一 个 只 有 200 个 左右 用 户 的 公 
司 ， 现 在 想 对 儿 个 部 门 组 成 几 个 独立 的 子 网 ， 如 果 仍 按 原 来 的 标准 网 
络 分 类 ， 则 必须 使 用 几 个 C 类 了 网络， 但 每 个 子 网 只 有 几 十 个 用 户 ， 所 
以 每 个 子 网 所 当 费 的 也 地 址 数 非常 多 。 如 果 采 用 了 VLSM 技 术 重 新 划 
分 子 网 后 ， 束 可 以 仅 使 用 一 个 C 类 网 络 来 容纳 多 个 部 门 子 网 了 ， 而 且 
每 个 部 门 都 古 独 立 的 子 网 ， 就 像 以 前 多 个 C 类 网 络 一 样 。 


8.2.2 ”全 0 子 网 与 全 1 子 网 


全 0 子 网 和 全 1 子 网 是 针对 进行 子 网 划分 后 子 网 ID 部 分 的 取 值 而 言 
的 。 全 0 子 网 代表 的 是 对 应 子 网 的 子 网 ID 部 分 各 位 都 古 0， 是 第 一 个 子 
网 ， 而 全 1 子 网 代表 的 是 对 应 子 网 的 子 网 ID 部 分 各 位 都 是 1， 十 最 后 一 
个 于 网 * 


按照 RFC950 参 考 规定 ， 划 分 子 网 后 ， 只 有 n-2 个 可 用 的 子 网 \n 表 
示 总 的 子 网 数 ) ， 第 一 个 子 网 (也 就 是 全 0 子 网 ) 和 最 后 一 个 子 网 (也 
就 是 全 1 子 网 ) 不 可 用 。 但 是 在 后 来 RFC1878 规 定 中 ， 该 项 规定 已 被 废 
止 了 ,现在 的 设备 基本 上 都 普 裔 支持 RFC1878。 现 在 来 说 ， 全 0 子 网 和 
全 1 子 网 事实 上 都 是 可 以 用 的 ， 因 为 有 了 CIDR， 可 以 实现 多 子 网 路 由 
聚合 。 有 些 比 较 老 的 设备 还 专门 配备 了 一 些 命令 来 支持 它们 ， 如 在 
Cisco 路 由 器 中 可 以 通过 “ip subnet-zero” 命 令 配置 来 实现 全 0 子 网 可 用 。 


现在 以 一 个 示例 来 说 明 ， 为 什么 在 RFC950 要 规定 全 0 和 全 1 子 网 不 
能 用 。 假 设 我 们 有 一 个 网 络 : 192.168.0.0/24， 现 在 要 划分 成 两 个 子 
网 ， 那 么 按照 RFC950， 应 该 使 用 /26 〈 借 用 2 个 主机 ID 位 ， 而 不 是 /25 只 
背 用 一 个 主机 ID 位 ) ， 因 为 如 果 是 /25 则 只 划分 了 两 个 子 网 ， 而 根据 规 
定 ， 第 一 个 子 网 〈 全 0 子 网 ) 和 最 后 一 个 子 网 (全 1 子 网 ) 都 不 能 
这 样 一 来 就 没有 可 用 的 子 网 了 。 按 /26 划 分 方式 可 以 得 到 得 到 两 个 可 以 


使 用 的 子 网 192.168.0.64 和 192.168.0.128， 第 一 个 子 网 192.168.0.0 和 最 
后 一 个 子 网 192.168.0.192 不 可 用 。 


下 面 来 分 析 一 下 各 种 网 络 的 网 络 地 址 和 广播 地 址 。 


口 对 于 没 划 分 子 网 前 的 192.168.0.0/24， 网 络 地 址 是 192.168.0.0， 
广播 地 址 是 192.168.0.255 。 


口 对 于 重新 划分 子 网 后 的 192.168.0.0/26 子 网 ， 网 络 地 址 是 
192.168.0.0， 广 播 地 址 是 192.168.0.63。 


口 对 于 重新 划分 子 网 后 的 192.168.0.64/26 子 网 ， 网 络 地 址 是 
192.168.0.64， 广 播 地 址 是 192.168.0.127。 


口 对 于 重新 划分 子 网 后 的 192.168.0.128/26 子 网 ， 网 络 地 址 是 
192.168.0.128， 广 播 地 址 是 192.168.0.191。 


口 对 于 重新 划分 子 网 后 的 192.168.0.192/26 子 网 ， 网 络 地 址 是 
192.168.0.192， 广 播 地 址 是 192.168.0.255。 


从 上 可 以 看 出 ， 重 新 按 /26 划 分 的 第 一 个 子 网 192.168.0.0/26 的 网 络 
地 址 和 没有 划分 子 网 时 的 192.168.0.0/24 的 网 络 地 址 是 一 样 的 ， 都 为 
192.168.0.0。 而 重新 划分 后 的 最 后 一 个 子 网 192.168.0.192/26 的 广播 地 
址 和 没有 划分 子 网 时 的 192.168.0.0/24 的 广播 地 址 也 是 一 样 的 ， 都 为 
192.168.0.255。 在 CIDR 正 式 使 用 以 前 ， 这 样 的 重 琶 将 导致 极 大 的 混 


乱 。 比 如 ， 一 个 发 往 192.168.0.255 的 广播 是 发 给 主 网 络 的 还 是 子 网 
的 ， 就 不 清楚 了 。 这 就 是 为 什么 在 当时 不 建议 使 用 全 0 和 全 1 子 网 的 原 
因 了 。 但 在 今天 ，CIDR 已 经 非常 普及 了 ， 通 过 地 址 前 缀 表示 形式 惑 可 
以 很 清楚 地 知道 具体 要 发 往 哪个 网 络 了 ， 所 以 一 般 不 需要 再 考虑 这 个 
问题 。 但 本 节 仍 以 RFC950 规 定 为 标准 进行 介绍 ， 确 认 需 要 使 用 第 一 个 
和 最 后 一 个 子 网 时 直接 使 用 即 可 ， 子 网 的 划分 方法 是 一 样 的 。 


8.2.3 VLSM 子 网 划分 方法 


许多 读者 朋友 觉得 子 网 划分 好 像 非 常 难 ， 他 们 总 也 搞 不 清楚 。 其 
实 子 网 划分 很 商 单 。 


在 子 网 划分 类 试题 或 者 具体 工 网 络 程 中 不 外 平 两 种 情形 : 


1) 已 知 要 划分 的 子 网 数 和 最 大 地 址 数 ， 求 子 网 掩 码 、 子 网 地 址 范 
、 网 络 地 址 和 广播 地 址 ， 其 基本 计算 步骤 如 下 : 


a) 根据 所 需 的 子 网 数 和 最 大 地 址 数 确定 划分 子 网 后 的 新 网 络 ID 长 
度 和 新 主机 ID 长 度 ; 


b) 根据 新 主机 ID 长 度 确 定子 网 划分 后 各 子 网 的 地 址 块 大 小 ,由 
此 可 进一步 确定 各 子 网 的 地 址 范围 、 网 络 地 址 和 广播 地 址 ; 


c) 根据 下 面 的 公式 得 出 划分 子 网 后 各 子 网 共同 的 子 网 掩 码 。 


新 子 网 掩 码 = 原 网 络 ID. 新 主机 ID 中 各 字 节 分 别 用 256- 各 子 地 址 块 
(各 字 节 的 值 之 间 以 小 圆 点 分 隔 ) 


2) 已 知 子 网 地 址 前 绥 或 子 网 掩 码 ， 求 子 网 地 址 范围 、 网 络 地 址 和 
广播 地 址 。 其 基本 计算 步 又 如 下 : 


a) 根据 子 网 的 地 址 前 绥 或 子 网 掩 码 确 定 该 子 网 地 址 块 大 小 ; 


b) 根据 地 址 块 大 小 ， 可 进一步 确定 该 子 网 的 地 址 范围 、 网 络 地 址 
和 广播 地 址 ; 


从 以 上 这 两 种 情形 的 计算 步骤 中 可 以 看 出 ， 最 关键 的 步骤 都 是 要 
确定 子 网 的 地 址 块 大 小 〈 也 就 是 子 网 中 的 IPv4 地 址 数 ， 也 肯定 是 22 ，n 
代表 “主机 ID” 位 数 ) 。 知 道 了 地 址 块 大 小 就 知道 了 包括 主机 ID 部 分 各 
字 节 的 子 地 址 块 大 小 ， 因 为 总 的 地 址 块 大 小 等 于 主机 ID 部 分 的 各 字 节 

(也 就 是 各 个 8 位 组 ) 中 2 的 对 应 二 进 制 位 数 次 方 。 如 主机 ID 中 包括 
IPv4 地 址 第 三 个 字 节 的 后 面 4 位 和 第 四 个 字 节 ， 则 所 划分 的 子 网 的 两 个 
子 地 址 块 分 别 是 24 (16) 和 28 (256) 。 


下 面 通过 一 个 具体 的 示例 来 解释 上 面 给 出 的 狐 子 网 掩 码 计算 公 
a 


现 假 设 已 知 一 个 C 类 标准 网 络 经 子 网 划分 后 的 地 址 块 大 小 为 64。 
经 分 析 可 知 ， 新 主机 ID 部 分 仅 为 最 后 一 个 字 节 (因为 一 个 完整 字 市 的 
地 址 块 大 小 256， 而 64 小 于 256) ， 又 因原 网 络 ID 为 255.255.255 (因为 
原 网 络 中 一 个 C 类 网 络 ) 。 根 据 上 面 的 公式 可 以 得 出 子 网 的 子 网 掩 码 
为 255.255.255. (256-64) ， 即 255.255.255.192。 


再 例如 ， 已 知 一 个 B 类 网 络 经 子 网 划分 后 的 地 址 块 大 小 为 1024。 
经 分 析 可 知 ， 新 主机 ID 分 布 在 最 后 两 个 字 节 中 (因为 这 里 的 地 址 块 大 


小 为 1024， 大 于 一 个 字 厄 的 地 址 块 大 小 256， 而 小 于 两 个 字 市 的 地 址 块 
大 小 65536) 。 再 因 1024=4x256 〈 之 所 以 要 乘 256， 那 是 因为 在 这 种 情 
况 下 IPv4 地 址 中 最 后 一 个 字 节 肯定 全 部 属于 主机 ID 部 分 ， 它 的 大 小 就 
是 256) ， 所 以 可 以 得 知 这 个 子 网 地 址 中 的 两 个 子 地 址 大 小 分 别 是 4 和 
256。 又 因原 网 络 ID 为 255.255 (因为 原 网 络 为 一 个 B 类 网 络 ) ， 这 样 根 
据 以 上 公式 就 可 以 很 快 得 出 子 网 的 子 网 掩 码 为 255.255. (256-4) . 
(256-256) ， 即 255.255.252.0。 


下 市 将 结合 具体 的 示例 对 以 上 这 两 种 情形 下 划分 子 网 的 方法 进行 
思 


8.2.4 VLSM 子 网 划分 示例 


本 节 针 对 上 节 介 绍 的 两 种 典型 情形 介绍 一 些 具体 的 VLAM 子 网 划 
分 示例 ， 同 时 还 将 介绍 一 个 二 级 子 网 划分 的 示例 ， 以 说 明 多 级 子 网 划 
分 的 方法 。 

1. 已 知 所 需 子 网 数 和 最 大 地 址 数 情 形 下 的 子 网 划分 示例 

【示例 1】 一 公司 原来 使 用 的 是 192.168.1.0/24 这 个 标准 网 络 ， 现 想 
为 公司 中 每 个 部 门 〈 共 6 个 ) 单独 配置 一 个 子 网 ， 其 中 最 大 一 个 部 门 要 


分 配 IPv4 地 址 的 数量 不 超过 25 个 。 求 每 个 子 网 的 子 网 掩 码 、 地 址 范 
围 、 网 络 地 址 和 广播 地 址 。 


这 个 示例 是 已 知 要 划分 的 子 网 数 和 最 大 地 址 数 。 有 具体 的 划分 方法 
很 简单 ， 先 结合 所 需 的 子 网 数 和 最 大 地 址 数 确 定子 网 的 网 络 ID 和 主机 
ID， 然 后 根据 主机 ID 确 定子 网 的 地 址 块 大 小 ， 其 他 的 就 自然 确定 了 。 


下 面 是 具体 的 计算 步骤: 

1) 本 示例 中 ， 部 门 数 为 6 个 ， 但 我 们 知道 YLSM 所 划分 的 子 网 数 
都 必须 是 2 ， 可 以 看 到 与 6 最 接近 的 束 是 划分 成 8 个 子 网 。 而 划分 8 个 
子 网 需要 向 主机 ID 借 3 位 ， 这 样子 网 的 主机 ID 位 数 就 仅 有 5 位 (8-3) 
了 ， 则 每 个 子 网 可 使 用 的 IPv4 地 址 数 为 30 个 (23 =32， 再 减 去 每 个 子 


网 中 不 可 分 配给 节点 使 用 的 网 络 地 址 和 广播 地 址 ) ， 恰 好 符合 该 公司 
中 各 部 门 的 最 大 地 址 数 要 求 。 


2) 知道 了 新 主机 ID 大 小 ， 也 就 是 知道 了 各 子 网 的 地 址 块 大 小 。 
本 示例 中 新 主机 ID 共 5 位 ， 大 小 为 32 (25 ) 。 


3) 根据 以 上 得 出 的 地 址 块 大 小 ， 再 根据 以 上 下 介绍 的 公式 可 得 出 
子 网 掩 码 为 : 原 网 络 ID (255.255.255) 。 (256-32) ， 即 
255.255.255.224 。 


4) 同样 ， 知 道 了 地 址 块 大 小 ， 也 就 是 知道 了 每 个 子 网 的 地 址 范 
。 本 示例 的 地 址 块 大 小 为 ?22， 也 就 是 把 整个 原来 C 类 网 络 中 256 个 地 
址 按 每 块 32 地 址 划分 成 8 等 份 《要 注意 的 是 ， 第 一 个 地 址 要 从 0 开始 计 
算 ) ， 得 到 的 8 个 子 网 的 地 址 范围 如 下 : 192.168.1.0~192.168.1.31、 
192.168.1.32~192.168.1.63、192.168.1.64~192.168.1.95、 


192.168.1.96~192.168.1.127、192.168.1.128~192.168.1.159、 
192.168.1.160~192.168.1.191 、192.168.1.192~192.168.1.223、 


192.168.1.224~192.168.1.225。 


各 了 于 网 的 地 址 范围 知道 了 ， 目 然 束 知道 了 它们 的 网 络 地 址 和 广播 
地 址 了 。 每 个 子 网 的 网 络 地 址 是 对 应 地 址 段 中 的 第 一 个 地 址 ， 每 个 子 
网 的 广播 地 址 是 对 应 地 址 段 中 的 最 后 一 个 地 址 。 然 后 随便 选择 其 中 5 个 
子 网 使 用 即 可 ， 最 好 是 5 个 连续 的 了 网， 这 样 方便 进行 路 由 汇总 。 同 时 


如 果 你 的 设备 不 支持 全 0 子 网 和 全 1 子 网 的 话 ， 则 不 要 选择 第 一 个 和 最 
后 一 个 子 网 。 


【示例 2】 某 公司 想 把 原来 使 用 的 172.16.0.0/8 标 准 网 络 分 成 12 个 子 
网 ， 其 中 一 个 最 大 的 子 网 节点 数 在 4000 个 左右 。 求 每 个 子 网 的 子 网 掩 
码 、 地 址 范围 、 网 络 地 址 和 广播 地 址 。 


这 个 示例 同样 是 已 知 要 划分 的 子 网 数 和 最 大 地 址 数 ， 具 体 的 划分 
方法 很 商 单 与 上 示例 一 样 。 下 面 是 具体 的 计算 步骤 : 


1) 本 示例 中 要 划分 成 12 个 子 网 ， 与 12 最 接近 的 可 划分 子 网 数 就 是 
16， 由 此 可 见 要 向 原来 的 主机 ID 借 4 位 (24 =16) ， 也 就 是 第 三 个 8 位 
组 的 高 4 位 。 这 样 一 来 子 网 的 主机 ID 位 数 就 仅 有 12 (16-4) 位 了 ， 则 每 
个 子 网 可 使 用 的 IPv4 地 址 数 为 4094 (2?? -2) ” (同样 是 因为 要 减 去 每 个 
子 网 中 不 可 分 配给 节点 使 用 的 网 络 地 址 和 广播 地 址 ) 个 ， 恰 好 符合 该 
公司 中 最 大 子 网 地 址 数 4000 的 要 求 。 


2) 知道 了 新 主机 ID 大 小 ， 也 就 是 知道 了 各 子 网 的 地 址 块 大 小 。 
本 示例 中 新 主机 ID 共 12 位 ， 总 地 址 块 大 小 为 4096 (212 ) 。 这 个 地 址 
块 是 分 布 在 第 三 个 字 节 和 第 四 个 字 节 中 ， 第 三 个 字 节 有 最 低 的 4 位 ， 对 
应 的 子 地 址 块 大 小 为 16， 而 第 四 个 字 节 包括 了 全 部 的 8 位 ， 对 应 的 子 地 
址 块 大 小 为 256。 


3) 根据 以 上 得 出 的 两 个 子 地 址 块 大 小 及 上 节 介 绍 的 公式 可 以 得 出 
子 网 掩 码 为 : 原 网 络 ID (255.255) . (256-16) . (256-256) ， 即 
255.255.240.0。 


4) 同样 知道 了 总 地 址 块 大 小 ， 也 就 是 知道 了 每 个 子 网 的 地 址 范 
» 本 示例 的 地 址 块 大 小 为 4096， 也 就 是 把 整个 原来 B 类 网 络 中 65536 
个 地 址 按 每 块 4096 地 址 划分 成 16 等 份 ， 得 到 的 16 个 子 网 的 地 址 范围 如 
下 : 172.16.0.0~192.16.15.255 (172.16.0.0/20) 、 
172.16.16.0~172.16.31.255 (172.16.16.0/20) 、 
172.16.32.0~172.16.47.255 (172.16.32.0/20 


172.16.64.0~172.16.79.255 


( ) 
172.16.48.0~172.16.63.255 (172.16.48.0/20) 、 

(172.16.64.0/20) 

( ) 


172.16.80.0~172.16.95.255 (172.16.80.0/20 
172.16.96.0~172.16.111.255 (172.16.96.0/20) 、 
172.16.112.0~172.16.127.225 (172.16.112.0/20 
172.16.128.0~172.16.143.225 (172.16.128.0/20 
172.16.144.0~172.16.159.225 (172.16.144.0/20 
172.16.160.0~172.16.175.225 
172.16.176.0~172.16.191.225 (172.16.176.0/20 


172.16.192.0~172.16.207.225 


) 
) 
) 
172.16.160.0/20) 、 
) 
172.16.192.0/20) 

) 


( 
( 
( 
( 
( 
( 


172.16.208.0~172.16.223.225 (172.16.208.0/20 


172.16.224.0~172.16.239.225 (172.16.224.0/20) 
172.16.240.0~172.16.255.225 (172.16.240.0/20) 


同样 ， 知 道 了 各 子 网 的 地 址 范围 ， 自 然 就 知道 了 它们 的 网 络 地 址 
和 广播 地 址 。 然 后 随便 选择 其 中 12 个 子 网 使 用 即 可 ， 最 好 是 12 个 连续 
的 子 网 ， 这 样 方便 进行 路 由 汇总 。 同 时 如 果 你 的 设备 不 支持 全 0 子 网 和 
全 1 子 网 的 话 ， 则 不 要 选择 第 一 个 和 最 后 一 个 子 网 。 


【示例 3】 每 个 子 网 有 不 超过 58 个 六 点 要 分 配 IPv4 地 址 ， 最 合适 的 
子 网 掩 码 是 () 


A.255.255.255.192 


B.255.255.255.248 


C.255.255.255.224 


D.255.255.255.240 


这 道 题 很 简单 ， 也 是 给 出 了 子 网 中 的 最 大 地 址 数 ， 那 惑 是 58 个 。 
由 此 可 见 ， 最 恰当 的 方式 是 对 一 个 C 类 标准 网 络 进行 子 网 划分 ， 因 为 
58 小 于 一 个 字 节 的 地 址 数 256。 而 地 址 块 中 与 58 最 接近 的 一 个 就 是 64 
(注意 ， 地 址 块 都 是 2 ，n 代 表 主 机 ID 的 位 数 ) ， 即 26 。 这 样 一 来 立 
即 可 得 出 它 的 子 网 掩 码 为 255.255.255. (256-64) ， 即 
255.255.255.192 。 


2. 已 知 子 网 地 址 前 缀 或 子 网 掩 码 的 情形 下 的 子 网 划分 示例 


这 种 情形 下 ， 子 网 抗 码 的 相关 计算 就 更 容易 了 ， 可 以 直接 通过 地 
址 前 缀 或 子 网 掩 码 得 出 地 址 块 大 小 ， 然 后 算出 其 他 方面 ， 如 地 址 范 
` 网 络 地 址 和 广播 地 址 。 


【示例 4】IPv4 地 址 为 10.32.0.0， 子 网 掩 码 为 255.224.0.0 的 子 网 中 
最 大 可 分 配给 主机 的 IPv4 地 址 是 什么 。 


这 道 题 也 是 属于 上 节 介 绍 的 第 二 种 情形 ， 已 知 了 子 网 的 子 网 掩 
码 。 这 时 可 根据 子 网 掩 码 255.224.0.0 很 快 得 出 该 子 网 中 的 主机 ID 分 布 
在 IPv4 地 址 后 面 三 个 字 节 中 ， 各 自 的 子 地 址 块 大 小 分 别 是 : 32 (256- 
224) 、256 (256-0) 、256 (256-0) 。 


在 这 种 主机 ID 分 布 在 多 个 字 节 的 情形 中 ， 起 关键 作用 的 就 是 包含 
主机 ID 中 的 第 一 个 字 节 ， 如 这 里 IPv4 地 址 中 第 二 个 字 节 的 “224”， 相 当 
于 告知 了 该 字 节 中 的 子 地 址 块 大 小 就 是 32 (256-224) ， 由 此 很 快 可 以 
得 出 各 子 网 的 该 字 广 取 值 范围 就 依次 是 0~31、32~63、64~95，..….…... 题 
中 给 出 的 10.32.0.0 恰 好 在 第 二 个 子 网 中 ， 它 的 IPv4 地 址 段 为 
10.32.0.0~10.63.255.255， 因 为 广播 地 址 不 能 分 配给 主机 使 用 ， 所 以 该 
子 网 中 可 分 配给 主机 使 用 的 最 大 IPv4 地 址 就 是 10.63.255.254。 


【示例 5】IPv4 地 址 为 202.112.14.137， 子 网 掩 码 为 
255.255.255.224， 所 在 子 网 的 网 络 地 和 广播 地 址 各 是 什么 。 


这 道 题 也 是 属于 上 节 介 绍 的 第 二 种 情形 ， 已 知 了 子 网 的 子 网 掩 
码 。 这 时 可 根据 子 网 掩 码 255.255.255.224 得 出 其 地 址 块 大 小 为 32 
(256-224) 。 因 为 它 是 一 个 C 类 标准 网 络 地 址 ， 所 以 主机 ID 仅 为 IPV4 
地 址 中 第 四 个 字 节 。 根 据 地 址 块 大 小 32， 可 以 把 第 四 个 字 市 的 值 划 分 
为 : 0~31、32~63、64~95、96~127、128~159、...... 由 此 可 见 
202.112.14.137 是 在 第 五 个 子 网 中 ， 网 络 地 址 惑 是 202.112.14.128， 广 播 


地 址 是 202.112.14.159 。 


3. 多 级 于 网 划分 示例 


上 面 介 绍 的 全 是 单 级 子 网 划分 的 示例 ， 多 级 子 网 划 的 方法 与 单 级 
子 网 划分 的 方法 是 一 样 ， 只 不 过 是 在 子 网 的 基础 上 进行 再 次 划分 。 下 
面 也 举 一 个 例 了 于 。 


【示例 6】 把 IPv4 子 网 10.32.0.0/11 划 分 成 8 个 子 网 ， 求 重新 划分 子 
网 后 的 子 网 掩 码 和 第 3 个 子 网 的 网 络 地 址 和 广播 地 址 。 


这 属于 上 节 介 绍 的 第 二 种 情形 ， 也 就 是 已 知 了 地 址 前 缀 ， 也 就 相 
当 于 已 知 了 子 网 掩 码 。 本 示例 是 地 址 前 缀 为 11， 也 就 是 原子 网 中 的 子 
网 掩 码 中 前 11 位 全 为 1， 后 21 位 全 为 0， 得 到 子 网 掩 码 为 255.224.0.0。 


现 要 对 10.32.0.0/11 子 网 进行 二 次 子 网 划分 ， 且 划分 的 子 网 数 是 8 
个 ， 也 就 是 要 再 向 主机 ID 借 3 位 ， 由 此 可 知 新 划分 的 子 网 中 网 络 ID 一 
共有 14 位 (11+3) ， 得 到 新 子 网 掩 码 为 255.252.0.0。 


得 出 了 新 子 网 掩 码 后 就 可 以 得 出 属于 主机 ID 部 分 的 字 市 的 子 地 址 
块 大 小 (分 别 用 256 去 减 即 可 ) 。 从 新 子 网 掩 码 为 255.252.0.0 可 以 得 
出 ,“ 主 机 ID? 分 布 在 第 二 个 、 第 三 个 和 第 四 个 字 节 中 ， 各 自 的 子 地 址 
块 大 小 分 别 为 4 (256-252) 、256 (256-0) 、256 (256-0) 。 同 样 关 键 
是 第 一 个 属于 “主机 ID” 的 字 节 的 子 地 址 块 大 小 ， 即 4。 所 以 10.32.0.0/11 
重新 划分 子 网 后 的 第 二 个 字 市 的 值 是 以 4 为 单位 进行 划分 的 。 从 第 一 个 
新 子 网 开始 ， 第 二 个 字 节 的 值 依次 是 32、35、39、43、47、51、55、 
59、63。 题 中 所 求 的 第 三 个 子 网 惑 是 第 二 个 字 闻 值 为 39 的 子 网 ， 它 的 
地 址 段 范围 为 10.39.0.0~10.43.255.255， 其 网 络 地 址 和 子 网 地 址 自然 就 
分 别 为 10.39.0.0/14 和 10.43.255.255/14。 


8.2.5 子 网 聚合 方法 及 示例 


在 一 些 比 较 大 的 企业 中 ， 我 们 可 能 已 经 通过 YLSM 技 术 为 它们 的 
部 门 ， 或 者 分 公司 划分 了 许多 子 网 。 这 样 做 的 目的 我 们 已 经 知道 ， 一 
是 可 以 提高 IPV4 地 址 的 利用 率 ， 二 是 减 小 广播 域 (也 就 是 “广播 范 
围 ” 的 意思 ) 大 小 ， 降 低产 生 广播 风暴 的 可 能 ;三 是 可 以 提高 网 络 的 安 
全 性 。 但 是 ， 这 样 进行 子 网 划分 后 也 会 市 来 一 些 负面 影响 ， 如 为 了 使 
得 各 子 网 的 互通 ， 在 各 路 由 右 的 路 由 表 中 就 可 能 需要 深 加 许多 子 网 级 
的 路 由 条 目 ， 使 得 整个 网 络 的 路 由 表 变 得 更 为 复杂 了 ， 影 啊 整 个 网 络 
的 路 由 性 能 。 


这 时 我 们 就 得 使 用 另 一 项 ITPv4 技 术 一 CIDR (无 类 别 域 间 路 
由 ) 。CIDR 可 以 把 一 些 连 续 的 多 个 小 子 网 路 由 汇总 成 一 条 大 网 络 的 路 
由 ， 这 样 通 过 这 一 条 大 网 络 路 由 条 目 就 可 实现 这 些 子 网 间 的 路 由 。 最 
终 实 现 减 少 路 由 表 中 的 路 由 条 目 和 提高 路 由 性 能 的 目的 。CIDR 可 以 看 
成 是 VLSM 子 网 划分 的 逆 过 程 ， 是 把 多 个 小 子 网 聚合 成 一 个 大 的 子 网 
或 标准 有 类 网 络 ， 但 必须 同时 借助 VLSM 来 实现 ， 所 涉及 的 计算 主要 
就 是 子 网 掩 码 ， 因 为 子 网 掩 码 与 IPv4 地 址 一 起 就 可 以 确定 路 由 中 的 具 
体 目的 网 络 。 


其 实 子 网 聚合 与 前 面 介绍 的 子 网 划分 实现 机 制 上 是 一 样 的 ， 就 是 
通过 改变 网 络 的 子 网 掩 码 长 度 来 调整 网 络 的 大 小 。 不 同 的 只 是 子 网 划 
分 是 把 网 络 ID 向 主机 ID 扩 展 〈 可 以 理解 为 向 右 走 ) ， 也 就 是 网 络 ID 各 
主机 ID 借 位 ， 缩 小 网 络 。 而 子 网 聚合 则 相反 ， 有 是 把 主机 ID 癌 网 络 ID 扩 
展 (可 以 理解 为 回 左 走 ) ， 也 就 是 主机 ID 疝 网 络 ID 借 位 ， 扩 大 网 络 。 
当然 ， 在 实际 的 网 络 组 建 中 ， 采 用 子 网 聚合 的 情况 是 极其 少见 的 ， 
CIDR 路 由 汇总 也 是 由 路 由 器 自动 进行 的 。 


既然 子 网 聚合 和 子 网 划分 都 古 通 过 借 位 来 实现 的 ， 所 以 它们 的 本 
质 还 十 一 样 的 。 在 子 网 划分 中 向 主机 ID 借 n 位 束 可 以 划分 成 27 个 大 小 
相等 的 连续 子 网 ， 而 在 这 里 介绍 的 子 网 队 合 中 是 向 网 络 ID 借 n 位 束 可 
以 聚合 22 个 小 相等 的 连续 子 网 。 


子 网 聚合 的 基本 思想 束 古 利用 连续 多 个 子 网 或 标准 网 络 的 网 络 地 
址 中 相同 的 部 分 保留 作为 新 网 络 的 网 络 ID 部 分 ， 不 同 的 部 分 作为 新 网 
络 的 主机 ID 部 分 。 然 后 由 新 网 络 的 网 络 ID 位 数 可 以 得 出 新 网 络 的 子 网 
掩 码 。 当 然 实 际 上 还 可 以 求 出 聚合 后 新 网 络 的 地 址 范围 、 网 络 地 址 和 
广播 地 址 。 下 面 也 通过 几 个 具体 的 示例 进行 介绍 。 


【示例 1】 把 192.168.1.0/27、192.168.1.32/27、192.168.1.64/27、 


192.168.1.96/27 这 四 个 连续 子 网 进行 聚合 。 


把 这 四 个 连续 子 网 的 网 络 地 址 用 二 进 制 形 式 表示 如 下 : 


11000000.10101000.00000000.00000000 


11000000.10101000.00010000.00000000 


11000000.10101000.00011000.00000000 


11000000.10101000.01100000.00000000 


从 以 上 可 以 看 出 ， 四 个 子 网 的 网 络 地 址 中 相同 的 部 分 就 是 用 深 颜 
色 标 注 的 这 部 分 ， 即 11000000.10101000.0， 把 这 些 位 全 部 置 1， 即 得 出 
聚合 网 络 的 子 网 拖 码 为 : 255.255.128.0。 


【示例 2】 率 合 192.168.4.0/24、192.168.5.0/24、192.168.6.0/24、 
192.168.7.0/24 这 四 个 标准 网 络 。 


把 这 四 个 标准 网 络 的 网 络 地 址 转换 成 如 下 二 进 制 形式 : 


11000000.10101000.00000100.00000000 


11000000.10101000.00000101.00000000 


11000000.10101000.00000110.00000000 


11000000.10101000.00000111.00000000 


结 末 得 出 相同 部 分 共有 22 位 ， 很 快 得 出 诊 合 后 的 于 网 掩 码 为 
255.255.252.0。 


经 验 之 谈 这 里 要 特别 注意 的 一 点 是 ， 用 于 “ 子 网 聚合 ”的 标准 网 
络 或 子 网 必须 是 连续 的 ， 但 连续 情况 不 同 ， 汇 总 的 结果 也 不 一 样 ， 如 
聚合 第 1~ 第 4 个 子 网 ， 与 聚合 第 2~ 第 5 个 子 网 ， 虽 然 都 是 聚合 四 个 子 
网 ， 但 结果 就 完全 不 一 样 ， 具 体 来 讲 比 较 复杂 ， 所 以 也 没有 一 个 统一 
的 方法 可 以 很 快 得 出 聚合 后 网 络 的 子 网 掩 码 。 我 们 还 是 采取 上 述 方 
法 ， 把 每 个 子 网 的 网 络 地 址 用 二 进 制 列 出 来 ， 然 后 找 它 完全 相同 的 连 
续 位 ， 即 可 得 到 新 网 络 的 子 网 掩 码 。 但 总 的 来 说 有 这 样 一 个 规律 ， 驶 
征 新 的 子 网 掩 码 每 增加 一 位 ， 新 的 缚 合子 网 数 就 是 原来 聚合 子 网 数 的 2 
倍 ， 反 之 亦 然 。 如 原来 通过 向 “网 络 ID” 借 3 位 可 以 聚合 了 8 个 连续 子 
网 ， 现 在 假设 再 继续 借 一 位 ， 则 可 以 率 合 的 连续 子 网 数 束 是 16 个 了 。 


【示例 3】 聚 合 192.168.5.0/24、192.168.6.0/24、192.168.7.0/24、 
192.168.8.0/24 这 四 个 标准 网 络 。 


同样 把 这 四 个 标准 网 络 的 网 络 地 址 转换 成 如 下 二 进 制 形式 : 


11000000.10101000.00000101.00000000 


11000000.10101000.00000110.00000000 


11000000.10101000.00000111.00000000 


11000000.10101000.00001000.00000000 


经 过 比较 发 现 ， 这 四 个 子 网 只 有 20 位 是 完全 相同 的 ， 也 就 是 聚合 
后 的 子 网 掩 码 是 20 位 ， 而 不 是 上 例 所 得 到 的 22 位 ， 尽 管 它们 聚合 的 都 
是 四 个 连续 网 络 。 究 其 原因 是 因为 给 出 的 这 四 个 网 络 不 能 聚合 成 一 个 
网 络 ， 而 必须 再 结合 前 、 后 连续 的 其 他 网 络 。 其 实 本 示例 的 聚合 结果 
是 对 192.168.0.0/24~192.168.15.0/24 共 16 个 网 络 的 聚合 结果 。 


8.3 IPv4 NAT 基 础 


由 于 IPv4 地 址 空间 太 小 ， 所 以 使 得 目前 Internet 正 面临 了 两 个 关键 
问题 : 一 是 公 网 IP 地 址 资源 的 匮乏 ， 二 是 路 由 表 的 日 益 庞 大 ， 路 由 效 
率 低 。NAT (Network Address Translation， 网 络 地 址 转换 ) 技术 与 前 
面 介绍 的 VLSM 和 CIDR 技 术 一 样 ， 其 出 发 点 都 是 为 了 解决 IPv4 地 址 

(主要 是 针对 公 网 IPv4 地 址 ) 不 足 的 问题 ， 提 高 现 有 IPv4 地 址 利用 
率 ， 但 它们 的 实现 机 制 不 一 样 。 前 面 介绍 了 VLSM 和 CIDR 古 通过 调整 
子 网 掩 码 长 度 来 充分 利用 现 有 IPv4 地 址 的 ， 而 这 里 所 介绍 的 NAT 技 术 
允许 组 织 内 部 网 络 使 用 非 全 局 可 路 由 IP 地 址 的 用 户 通 过 地 址 转换 为 全 
局 可 路 由 的 IP 地 址 来 访问 Internet， 以 降低 了 对 公 网 IP 地 址 的 需求 


NAT 服 务 是 运行 在 位 于 内 、 外 网 之 间 的 路 由 设备 上 的 ， 在 内 、 外 
网 用 户 之 间 通 信 时 对 数据 包 中 的 地 址 〈 可 能 是 源 地 址 ， 也 可 能 是 目的 
地 址 ) 进行 转换 。 在 当前 仍 是 IPv4 为 主流 协议 的 人 P 网 络 ，NAT 技 术 的 
应 用 非常 三 ， 因 为 它 可 以 市 约 紧 缺 的 公 网 IPv4 地 址 。 


8.3.1 NAT 的 主要 应 用 


NAT 服 务工 作 在 路 由 器 上 (同时 可 工作 在 三 层 交 换 机 或 防火 墙 
上 ) ， 通 常用 于 连接 两 个 网 络 ， 通 过 把 内 部 网 络 中 的 多 个 私 网 IPv4 地 


址 转换 为 合法 的 一 个 或 多 个 公 网 IPv4 地 址 ， 让 使 用 非 注 册 IPv4 地 址 的 
私有 IPv4 网 络 全 部 或 部 分 用 户 连 接 到 Internet， 或 者 允许 Internet 用 户 访 
问 内 部 网 络 设备 ， 如 邮件 服务 恬 。 


总 体 来 说 ，NAT 主 要 可 以 用 于 以 下 三 种 情形 ; 


(1) 无 足够 的 公 网 下 地 址 可 用 时 


当 想 要 连接 到 Internet， 但 网 络 中 并 不 是 每 个 用 户 都 有 全 局 、 合 法 
的 公 网 IP 地 址 时， 就 可 以 使 用 NAT 来 解决 。 在 连接 内 部 网 络 和 外 部 网 
络 的 边界 路 由 器 上 配置 NAT， 在 内 部 网 络 中 多 用 户 把 数据 包 发送 到 外 
部 网 络 之 前 把 这 些 用 户 的 数据 包 源 IP 地 址 中 的 内 部 本 地 地 址 转换 为 一 
个 或 者 少数 几 个 内 部 全 局 地 址 。 这 是 NAT 最 基本 的 功能 。 目 前 大 多 数 
路 由 器 共 至 上 网 方式 都 症 采用 这 种 NAT 应 用 方案 。 


(2) 重 构 网 络 卫 地址 部 署 


在 你 需要 改变 你 的 内 部 地 址 时 ， 你 可 以 使 用 NAT 来 进行 改变 ， 这 
样 可 以 节省 许多 工作 量 。 例 如 你 原来 采用 的 是 一 个 C 类 网 段 (如 
192.168.1.0) ， 后 来 由 于 用 户 数 增加 ， 导 致 IPv4 地 址 不 够 用 。 按 照常 
理 是 你 可 能 要 重新 采用 B 类 ， 甚 至 A 类 网 段 IP 地 址 为 网 络 中 的 用 户 重新 
分 配 。 但 这 样 一 来 ， 如 果 用 户 数 较 大 ， 重 新 配置 的 工作 量 可 能 非常 
多 


此 时 我 们 可 以 采用 NAI 方 式 ， 让 新 增加 的 用 户 单独 用 另 一 个 网 段 
的 IPv4 地 地 址 (如 192.168.2.0) ， 然 后 再 用 一 个 文 持 NAT 的 设备 与 原 
来 用 户 所 在 网 段 连接 起 来 ， 通 过 NAT 地 址 转换 功能 ， 只 需要 用 一 个 原 
来 网 段 的 IPv4 地 址 (如 192.168.1.254) 即 可 映射 到 新 网 段 中 所 有 用 户 
的 IPv4 地 址 。 这 时 新 网 段 就 相当 于 原来 网 段 的 一 个 设备 ， 但 可 以 实现 
两 个 网 段 处 于 同一 网 段 的 目的 因为 新 网 段 经 过 NAT 地 址 转换 后 也 为 
原来 网 段 中 的 地 址 ) 。 利 用 这 种 方法 大 大 减少 了 重新 配置 的 工作 量 。 
当然 ， 这 样 做 也 存在 一 定 的 不 便 ， 如 对 新 网 段 中 的 用 户 管理 存在 一 定 
难度 。 因 为 新 网 段 中 所 有 用 户 是 共享 一 个 原来 网 段 IP 地 址 的 。 


(3) 实现 简单 的 TCP 负 载 均 衡 


当 你 想 要 部 署 基本 的 TCP 负 载 均衡 时 ， 你 可 以 使 用 NAT 把 多 个 相 
同 服 务 絮 的 私 网 IPv4 地 址 映射 到 一 个 全 局 公 网 IPv4 地 址 ， 实 现 服务 絮 
的 TCP 负 载 均衡 。 这 是 NAT 的 TCP 负 载 均 衡 功 能 。 


8.3.2 ”与 NAT 相 天 的 主要 术语 


图 8-11 所 示 是 基本 NAT 应 用 网 络 结构 和 组 成 要 素 。 首 先 起 关键 作用 
的 当然 是 提供 NAT 服 务 的 网 络 设备 ， 通 常 是 路 由 器 (也 可 以 是 其 他 三 
层 设备 ， 如 三 层 交 换 机 和 防火 墙 等 ) 。 它 通过 两 个 接口 连接 内 、 外 两 
个 网 络 。 内 部 网 络 (Inside Network) 就 是 用 户 当前 所 在 网 络 ， 通 常 是 
指 用 户 私 有 局 域 网 ， 而 外 部 网 络 (Outside Network) 是 指 内 部 网 络 以 外 
的 其 他 所 有 网 络 ， 一 般 是 指 Internet 。 


Inside Network Outside Network 
(内 部 网 络 ) (外 部 网 络 ) 


Inside Host Outside Host 


图 8-11 NAT 应 用 拓扑 结构 的 基本 组 成 


下 面 吓 与 NAT 技 术 密 切 相 关 的 几 个 术语 描述 ， 这 对 理解 NAT 技 术 
工作 原理 非常 重要 。 


(1) 内 部 网 络 (Internal Network) 


内 部 网 络 通 稼 是 指 一 个 边缘 局 域 网 ， 使 用 内 部 网 络 IPv4 地 址 ， 尽 
管 它 也 可 以 是 注册 的 公 网 耻 地 址 ， 但 更 多 的 是 非 注 册 的 私 网 IP 地 址 。 使 
用 非 注 册 IPv4 地 址 的 所 有 计算 机 都 必须 使 用 NAT 和 转换 后 再 与 其 他 网 络 进 
行 通 信 ; 而 使 用 注册 的 公 网 IPv4 地 址 的 主机 如 果 是 在 由 路 由 器 隔离 的 
内 部 局 域 网 中 ， 也 是 需要 经 过 NAT 转 换 后 才能 直接 使 用 它 进行 访问 
的 。 所 以 总 之 ， 内 部 网 络 的 IPv4 地 址 都 必须 经 过 路 由 器 的 NAT 转 换 才 能 
访问 外 部 网 络 。 


(2) 外 部 网 络 (External Network) 


外 部 网 络 是 除 本 地 私有 网 络 以 外 的 所 有 其 他 网 络 ， 在 NAT 应 用 
中 ，Internet 是 最 常见 的 外 部 网 络 。 当 然 ， 外 部 网 络 也 可 以 是 其 他 私有 
网 络 ， 如 两 个 局 域 网 通过 路 由 器 相连 的 情况 下 。 所 以 外 部 网 络 上 的 用 
户 使 用 IP 地 址 同样 既 可 以 是 注册 的 ， 也 可 以 是 非 注 册 的 。 


经 验 之 谈 其实 内 部 网 络 与 外 部 网 络 只 是 相对 定义 的 ， 它 是 相对 
你 当前 所 在 的 网 络 的 而 言 的 ， 如 果 你 换 到 另 一 方 网 络 去 配置 (在 路 由 
器 连 接 的 是 两 个 局 域 网 的 情况 下 ) ， 这 时 内 、 外 部 网 络 的 角色 就 要 互 
换 了 本 


在 NAT 中 ， 除 了 以 上 两 个 网 络 类 型 的 定义 外 ， 还 依据 IPv4 地 址 十 在 
专用 网 络 还 生 在 公用 网 络 ， 以 及 通过 方 癌 是 流入 还 是 流出 有 不 同 的 定 
ce 


(3) 本 地 地 址 (Local address ) 


在 IPv4 地 址 中 ， 可 以 根据 IPv4 地 址 的 作用 范围 分 为 本 地 地 址 
(Local address) 和 全 局 地 址 (Global address) 两 大 类 。 


本 地 地 址 是 本 地 网 络 (可 以 是 内 部 网 络 ， 也 可 以 是 外 部 网 络 ) 内 
部 使 用 的 IP 地 址 ， 仪 在 本 地 网 络 有 效 ， 不 能 直接 用 来 访问 外 部 网 络 的 IP 
地 址 ， 不 可 路 由 ， 这 束 是 “本 地 ”两 字 的 含义 所 在 。 前 面 说 了 ， 内 部 网 
络 中 既 可 以 使 用 未 注册 的 私有 网 络 IP 地 址 ， 又 可 以 使 用 公 网 注册 的 IP 地 
址 ， 所 以 ， 本 地 地 址 既 可 以 是 通常 所 见 的 私 用 网 使 用 的 非 注 册 IP 地 
址 ， 也 可 以 古 在 公 网 中 使 用 的 注册 IP 地 址 ， 但 通常 古 指 私 网 I P 地 址 。 


因为 NAT 连 接 了 内 、 外 两 个 网 络 ， 所 以 在 本 地 地 址 中 又 有 两 类 ， 
一 类 是 用 于 内 部 网 络 的 内 部 本 地 地 址 (Inside Local Addresses) ， 一 类 
是 用 于 外 部 网 络 的 外 部 本 地 地 址 (Outside Local Addresses) 。 


内 部 本 地 地 址 (Inside local address) 


内 部 本 地 地 址 是 指 分 配给 内 部 网 络 主机 的 卫 地 址 。 这 个 耻 地 址 是 计 
算 机 操作 系统 ， 或 诸如 DHCP 之 类 的 服务 进行 分 配 的 ， 但 既 可 以 是 仅 限 
于 内 部 局 域 网 使 用 的 私有 非 注册 了 地 址 ， 也 可 以 是 由 ISP 统 一 分 配 的 注 
册 IP 地 址 。 它 们 都 是 在 内 部 网 络 使 用 的 ， 通 常 是 指 非 注 册 IP 地 址 。 


外 部 本 地 地 址 (Outside local address ) 


这 是 本 地 地 址 的 另 一 种 ， 与 内 部 本 地 地 址 性 质 一 样 ， 是 为 外 部 网 
络 主机 分 配 的 本 地 网 络 IP 地 址 ， 是 外 部 网 络 主机 对 内 部 网 络 用 户 呈 现 
的 IP 地 址 。 这 个 JP 地址 是 计算 机 操作 系统 或 诸如 DHCP 之 类 的 服务 进行 
分 配 的 ， 但 也 既 可 以 是 仅 限 于 内 部 局 域 网 使 用 的 私有 非 注册 IP 地 址 ， 
也 可 以 是 由 ISP 统 一 分 配 的 注册 IP 地 址 。 通 常 是 指 专用 网 络 使 用 的 非 注 
册 IP 地 址 。 


经 验 之 谈 ”这 里 所 说 的 内 部 本 地 址 和 外 部 本 地 地 址 不 是 路 由 器 上 
连接 内 、 外 部 网 络 的 接口 的 IP 地 址 ， 而 是 在 内 、 外 部 网 络 中 主机 分 配 
给 的 IP 地 址 。 这 一 后 一 定 要 搞 清 楚 。 


(4) 全 局 地 址 (Global address) 


全 局 地 址 是 与 本 地 地 址 相对 应 的 IP 地 址 ， 它 是 内 、 外 部 网 络 本 地 
址 转换 后 的 了 地址 的 ， 有 是 可 路 由 的 。 全 局 地 址 其 实 有 是 指 在 内 、 外 网 络 
中 间架 设 的 一 个 过 渡 性 网 络 的 了 地 址 。 内 、 外 部 网 络 相互 通信 都 需要 
先 把 对 应 的 本 地 地 址 转换 成 对 应 的 全 局 地 址 才能 与 对 方 网 络 进行 通 
信 。 考 虑 到 NAT 路 由 器 既 有 与 像 互联 网 这 样 连接 局 域 网 的 情形 ， 义 有 
连接 两 个 局 域 网 的 情形 ， 所 以 全 局 地 址 也 有 既 可 以 是 可 供 注 册 的 公 网 IP 
地 址 ， 也 可 以 是 非 注 册 的 私 网 也 地 址 。 但 NAT 的 应 用 主要 是 内 部 局 域 网 
与 Internet 的 连接 ， 所 以 外 部 网 络 一 般 是 Intemet， 这 样 ， 全 局 地 址 也 就 
一 般 是 公 网 注册 IP 地 址 了 。 


全 局 地 址 也 分 为 两 类 : 一 是 用 于 转换 内 部 本 地 地 址 的 内 部 全 局 地 
址 (Inside global address) ， 男 一 类 是 用 于 转换 外 部 本 地 地 址 的 外 部 全 
局 地 址 (Outside global address) 。 


内 部 全 局 地 址 (Inside global address) 


内 部 多 局 地 址 是 内 部 网 络 主机 对 外 部 网 络 用 户 呈 现 的 了 P 地 址 (可 
以 是 分 配给 路 由 器 连接 外 部 网 络 接口 的 人 P 地 址 ) ， 是 内 部 本 地 地 址 转 
换 后 的 地 址 。 通 常 它 是 由 ISP 分 配给 企业 用 户 内 部 网 络 使 用 的 注册 IP 地 
址 ， 但 也 可 以 是 服务 提供 商 分 配 、 在 本 地 注册 的 私 网 耻 地 址 。 通 过 NAT 
转换 后 ， 对 于 外 界 网 络 来 说 ， 它 们 扮演 的 是 一 个 或 多 个 内 部 本 地 址 IP 
地 址 ， 以 便 与 外 部 网 络 通 信 。 


外 部 全 局 地 址 (Outside global address) 


外 部 全 局 地 址 是 外 部 网 络 主机 分 配 到 的 外 部 网 络 IP 地 址 。 它 通常 
征 由 ISP 分 配给 企业 用 户 内 部 网 络 使 用 的 注册 I 地 址 ， 但 也 可 以 是 服务 
提供 丙 分 配 、 注 册 的 私 网 IP 地 址 。 


8.3.3 NAT 地址 基本 转换 原理 


在 私有 网 络 中 的 计算 机 是 使 用 内 部 本 地 地 址 (Inside Local 
Addresses) 进行 通信 和 的， 当 它们 需要 与 外 部 网 络 进行 通信 有 时， 就 需要 
为 他 们 配置 内 部 全 局 地 址 (Inside Global Addresses) 。 


忌 体 来 说 ，NAT 进 行 地 址 转换 的 过 程 整 是 本 地 地 址 与 全 局 地 址 之 
间 的 转换 过 程 ， 无 论 数据 包 是 从 内 部 网 络 发 往外 部 网 络 ， 还 是 从 外 部 
网 络 发 往 内 部 网 络 。 不 同 的 只 是 本 地 地 址 和 全 局 地 址 所 对 应 的 网 络 不 
同 ， 以 及 数据 包 重 新 封装 的 源 和 目的 地 址 不 同 。 具 体 如 图 8-12 所 示 。 


内 部 本 地 地 址 内 部 全 局 地 址 


内 部 私有 i rl 外 部 公用 
网 络 网 络 


~ 
外 部 本 地 地 址 外 部 全 局 地 址 


图 8-12 NAT 基 本 地 址 转换 原理 


在 以 上 转换 过 程 中 ， 当 数据 包 还 在 内 部 网 络 位 置 时 有 一 个 作为 源 
地 址 的 内 部 本 地 地 址 和 一 个 作为 目的 地 址 的 外 部 本 地 地 址 。 此 数据 包 
目 先 发 往 路 由 右 连 接 内 部 网 络 的 接口 中 。 当 数据 包 被 转发 到 外 部 网 络 
时 ， 数 据 包 的 源 地 址 丈 会 转变 为 内 部 全 局 地 址 ， 而 目的 地 址 被 转变 为 
外 部 全 局 地 址 ， 如 图 8-13 所 示 。 也 束 是 把 数据 包 的 所 有 源 和 目的 地 址 全 


部 由 本 地 地 址 转换 为 全 局 地 址 。 这 个 过 程 是 通过 NAT 中 的 本 地 址 与 全 
局 地 址 映 冉 条 目 来 实现 的 ， 所 以 事先 要 在 NAT 路 由 右上 配置 这 样 的 映 
别 条 目 。 


内 部 网 络 外 部 网 络 


DA SA DA SA 
Inside LocallOutside Local Inside GloballOutside Global -一 


图 8-13 NAT 的 详细 地 址 转换 原理 


相反 ， 当 数据 包 是 从 外 部 网 络 位 置 发 来 ， 并 且 仍 位 于 外 部 网 络 中 
时 ， 它 的 源 地 址 就 是 外 部 全 局 地 址 ， 目 的 地 址 就 是 内 部 全 局 地 址 。 相 
当 于 由 内 部 网 络 向 外 部 网 络 发 送 数 据 包 时 ， 外 部 网 络 主机 接收 到 的 数 
据 包 中 的 源 地 址 和 目的 地 址 的 互 换 。 而 当 数 据 包 被 路 由 天 转发 到 本 地 
网 络 时 ， 源 地 址 被 转变 为 外 部 本 地 地 址 ， 目 的 地 址 被 转变 为 内 部 本 地 
地 址 ， 也 相当 于 由 内 部 网 络 向 外 部 网 络 发 送 数 据 包 时 ， 内 部 网 络 主机 
发 送 的 数据 包 中 的 源 地 址 和 目的 地 址 的 互 换 。 


从 以 上 分 析 可 以 看 出 ， 由 内 部 网 络 癌 外 部 网 络 转换 时 ， 以 及 由 处 
部 网 络 向 内 部 网 络 转换 时 ， 了 P 报 文中 的 源 IP 地 址 (SA) 和 目的 IP 地 址 
(DA) 在 内 部 本 地 (Inside Local) 地 址 与 内 部 全 局 (Inside Global) 地 


址 ， 外 部 本 地 (Outside Local) 地 址 与 外 部 全 局 (Outside Global) 地 址 
之 间 的 转换 方式 。 


8.3.4 NAT 类 型 


在 NAT 路 由 器 中 虽然 可 以 配置 多 种 形式 的 NAT 地 址 转换 ， 但 总 体 

来 说 就 是 两 种 : 静态 NAT 和 动态 NAT。 在 动态 NAT 中 又 有 一 种 特殊 的 

NAT 形 式 ， 那 就 是 重 载 (Overloading) NAT， 也 就 是 通常 所 说 的 PAT 

(端口 地 址 转换 ) 。 而 还 有 一 种 针对 内 部 网 络 、 也 使 用 公 网 注册 IP 地 

址 的 这 种 特定 网 络 配置 情形 的 NAT 转 换 形 式 ， 也 就 是 后 面 将 要 介绍 的 

重 闪 (Overlapping) NAT。 它 既 可 以 静态 NAT 方 式 部 署 ， 也 可 以 动态 
NAT 方 式 部 署 。 下 面具 体 介 绍 这 几 种 NAT 类 型 。 


1. 静 态 NAT (Static NAT) 


静态 NAT 是 把 非 注册 IP 地 址 (如 本 地 局 域 网 IP 地 址 ) 一 对 一 地 映射 
到 公 网 注册 IP 地 址 (如 互联 网 人 P 地 址 ) 。 这 在 网 络 设备 需要 以 互联 网 卫 
地 址 访问 外 网 时 特别 有 用 。 但 一 定 要 注意 ， 这 里 仪 列举 了 单一 的 正方 
加 的 耳 地 址 转换 的 例子 ， 实 际 上 还 可 以 是 反方 癌 或 着 双方 癌 进 行 耻 地 址 
转换 的 ， 下 面 的 动态 NAT 和 复 用 NAI 也 一 样 可 以 有 正 向 、 反 向 、 或 者 
双 问 转换 方式 。 


图 8-14 所 示 的 是 一 个 静态 NAT 应 用 示例 (注意 箭头 方向 ) 。 路 由 器 
内 、 外 两 个 网 络 ， 左 侧 内 部 网 络 中 的 192.168.32.10、192.168.32.12 和 
192.168.32.15 这 三 台 主 机 使 用 的 私有 网 络 IP 地 址 ， 通 过 路 由 器 的 NAT 功 


能 最 终 对 应 转换 成 213.18.123.110、213.18.123.11 和 213.18.123.12 这 三 个 
公 网 耻 地 址 ， 让 对 方 看 到 的 也 是 这 三 个 公 网 耳 地址 。 


过 23 LO 
13.18.123.) 


@ = 


= 192.168.32.10 


S 网 mt 192.168.32.12 公 网 


L138 .1123 12 


aa 


= 192.168.32.15 


" 


图 8-14 静态 NAT 应 用 示例 
2. 动 态 NAT (Dynamic NAT) 


动态 NAT 可 把 一 个 非 注册 IP 地 址 动态 地 映射 到 一 个 注册 IP 地 址 池 中 
的 一 个 地 址 。 具 体 是 哪 两 组 IP 地 址 之 间 的 映射 关系 ， 还 要 看 所 配置 的 
具体 公用 IP 地 址 池 和 通信 时 间 。 但 最 终 非 注册 IP 地 址 与 注册 IP 地 址 还 是 
一 对 一 地 进行 映射 的 。 


图 8-15 所 示 是 一 个 动态 NAT 应 用 的 示例 。 内 网 中 的 三 个 JP 地址 与 一 
个 范围 为 213.18.123.100~213.18.123.150 的 公 网 IP 地 址 池 进 行动 态 映 
射 。 最 终 的 结果 是 ，192.168.32.10 映 射 为 213.18.123.116，192.168.32.12 
映射 为 213.18.123.112， 而 192.168.32.15 映 射 为 213.18.123.125，...…... 


213.18.123.112 (192.168.32.12 半 ”动态 NAT 


映射 表 
213.18.123 116(192 168.32 10) 
ws- 192.168.32.10 二 12321 1 
pm i 
专 网 ma 192.168.32.12 ZZ13.18:123.112 公 网 


213.18.123.123 


2 192.168.32.15 
P| 

图 8-15 动态 NAT 应 用 示例 
3. 重 载 或 复 用 NAT (Overloading NAT) 


重 载 NAT 和 是 动态 NAI 的 一 种 形式 。 它 通过 与 卫 地 址 的 不 同 端口 组 
合 ， 把 多 个 非 注 册 耳 地 址 映射 到 一 个 注册 卫 地 址 ， 也 束 是 通 音 所 说 的 
PAT (Port Address Translation， 端 口 地 址 转换 ) 。 通 过 PAT， 数 千 内 网 
用 户 都 可 以 仅 通过 一 个 公 网 卫 地 址 访问 Internet 。 


图 8-16 所 示 是 一 个 重 载 NAT 的 应 用 示例 。 示 例 中 本 地 网 络 中 的 所 有 
用 户 通 过 路 由 器 访问 公用 网 络 时 ， 都 将 映射 成 同一 个 公 网 JP 地 址 一 一 
213.18.123.100， 只 是 所 使 用 的 端口 不 同 而 已 (分别 为 101、102、103 号 
端口 ) 。 这 对 于 公 网 JP 地 址 比较 紧张 ， 而 内 网 中 叉 部 署 了 多 种 应 用 服 
务 器 时 特别 有 用 ， 可 以 通过 一 个 公 网 IP 地 址 配置 多 个 应 用 服务 器 。 


.4 192.168.32.10 213.18.123.100:101 
ee 
左 网 < 192 168.32 12 213.18.123.100:102 公 网 
Ee 1929.168.3%.15 213.18.123.100:103 
a ee nn 


图 8-16 重 载 NAT 应 用 示例 
4. 重 车 (Overlapping) NAT 


当 内 部 网 络 中 使 用 的 卫 地 址 是 外 部 网 络 中 注册 的 耳 地 址 时 (也 就 是 
内 、 外 部 网 络 使 用 的 是 相同 耳 地 址 段 时 ) ， 路 由 器 需要 维护 一 张 得 询 
表 ， 以 便 截 取 来 目 内 部 网 络 的 数据 包 ， 并 用 外 部 网 络 中 没有 使 用 的 注 
册 耳 地址 进行 奉 换 。 但 要 注意 ，NAI 路 由 器 必须 转换 内 部 网 络 本 地 地 址 
为 注册 的 唯一 (也 就 是 没有 被 使 用 的 ，IP 地 址 ， 同 时 也 必须 转换 外 部 
网 络 本 地 址 为 内 部 网 络 中 唯一 的 IP 地 址 。 这 有 既 可 以 通过 静态 NAT 来 实 
现 ， 又 可 以 通过 使 用 DNS 和 动态 NAT 来 实现 。 


经 验 之 谈 重合 NAT 主 要 应 用 于 使 用 公 网 人 P 地 址 的 内 部 网 络 服 务 右 
的 地 址 转换 ， 这 样 可 以 隐藏 内 部 网 络 服务 器 的 真实 公 网 耳 地 址 ， 有 利 
于 保护 服务 器 的 安全 。 因 为 经 过 NAT 转 换 后 ， 内 部 网 络 服务 器 对 外 呈 
现 的 是 另 一 个 公 网 下 地 址 ， 不 是 真实 的 服务 右 IP 地 址 。 


图 8-17 所 示 为 一 个 重 琶 NAT 的 应 用 示例 。 在 内 部 网 络 中 使 用 的 了 地 
址 段 为 237.16.32.xx (也 是 注册 的 公 网 IP 地 址 ) ， 而 外 部 网 络 主机 也 使 
用 这 个 地 址 段 。 这 时 ，NAT 路 由 器 需要 转换 内 部 网 络 中 的 本 地 IP 地 址 


(如 237.16.32.10) 为 一 个 区 别 于 外 部 网 络 的 另 一 网 段 的 全 局 地 址 (如 
213.18.123.103) ， 以 避免 与 外 部 网 络 中 的 用 户 造 成 潜在 的 冲突 。 同 时 
在 由 外 部 网 络 向 内 部 网 络 发 送 数据 时 ，NAIT 路 由 器 也 将 转换 内 部 全 局 
地 址 (如 213.18.123.103) 为 内 部 本 地 地 址 (如 237.16.32.10) 。 


237.16.32.10 D13.18.123.103 
ji i 人 一 一 公 网 
237.16.32.10 213.18.123.103 


图 8-17 重 闪 NAT 应 用 示例 


8.4 ”IPv6 地 址 基础 


前 面 介绍 了 IPv4 协 议 的 编 址 方案 ， 与 之 相 比 ，IPv6 的 编 址 方案 要 复 
杂 许 多 。IPV6 与 IPv4 协 议 相 比 ， 最 大 的 特征 就 是 地 址 空间 增 大 了 许多 
倍 ， 因 为 IPv6 地 址 的 位 数 由 原来 的 IPv4 地 址 的 32 位 激增 到 了 128 位 ， 相 
当 于 IPv4 地 址 空间 的 4 倍 。 与 IPv4 地 址 通常 是 采用 圆 点 分 隔 的 十 进 制 表 
示 类 似 ，IPv6 是 由 使 用 由 冒号 分 隔 的 十 六 进 制 数 表示 (每 段 4 位 十 六 进 
制 数 ， 相 当 于 16 位 二 进 制 数 ， 如 图 8-18 所 示 ) ， 且 在 IPv6 地 址 中 ， 十 六 
进 制 数 对 大 小 写 不 敏感 ， 也 就 是 大 、 小 写 任意 。 由 于 地 址 空间 扩展 了 3 
倍 ， 所 以 从 目前 看 来 ， 可 以 说 是 彻底 解决 了 IPv4 地 址 缺乏 的 问题 ， 据 
悉 IPv6 地 址 全 部 使 用 后 ， 可 以 使 全 球 每 个 人 可 以 拥有 平均 10 多 个 地 
址 。 


XXXX | XXXX XXXX | XXXX | 入 XXX | XXXX | 入 XXX 


128 位 二 进 制 ( 32 位 十 六 进 制 ) 


图 8-18 128 位 IPv6 地 址 格式 


8.4.1 IPv6 地 址 表示 形式 


IPv6 地 址 长 度 4 倍 于 IPv4 地 址 ， 表 达 起 来 的 复杂 程度 也 是 IPv4 地 址 
的 4 倍 。IPv6 地 址 的 基本 表达 方式 是 x:x:x:x:x:x:x:x， 其 中 的 一 个 “x” 是 一 
个 4 个 十 六 进 制 整数 ， 每 个 十 六 进 制 数 代表 4 位 二 进 制 ， 每 个 IPv6 地 址 
包括 8 个 整数 〈 也 就 是 8 个 地 址 块 ) ， 这 样 一 来 就 得 出 ，IPv6 总 的 位 数 
为 128 位 (4x4x8) 个 二 进 制 。 


在 IPV6 协 议 中 ， 一 个 128 位 地 址 空间 中 ， 人 允许 21”3 ， 即 340 282 366 
920 938 463 463 374 607 431 768 211 456 (或 约 等 于 3.4x1038 ) 个 (也 
就 是 43 个 43 亿 ) 可 能 的 地 址 。 而 在 IPv4 协 议 中 ， 一 个 32 位 地 址 空间 允 
许 2% 即 4 294 967 296 个 ( 约 43 亿 ) 可 能 的 地 址 。 由 此 可 见 ，IPv6 的 地 
址 空间 是 IPv4 的 2% 倍 。 与 IPv4 相 比 ， 地 址 空间 不 是 很 小 的 扩展 ， 而 是 
一 个 天 文 数 级 别 的 扩展 。 


1. 基 本 的 “冒号 十 六 进 制 * 表 示 形 式 


在 我 们 的 日 常 使 用 中 ，IPv4 地 址 是 每 8 位 以 点 分 十 进 制 形式 (每 个 
8 位 组 中 间 是 以 小 圆 点 分 隔 的 ) 来 表示 的 ， 如 192.168.10.12。 对 于 
IPV6，128 位 的 地 址 则 是 按 每 16 位 〈 有 是 IPv4 中 每 块 位 数 的 2 倍 ) 一 组 来 分 
隔 的 ， 每 个 16 位 块 转换 成 4 个 十 六 进 制 数 (注意 不 是 十 进 制 了 ) ， 这 样 
就 一 共 划 分 成 了 8 块 (也 是 IPv4 块 数 的 2 倍 ) 。 且 相 邻 的 16 位 块 是 以 半 
角 冒 号 〈 不 再 是 IPv4 地 址 中 的 小 圆 点 ) 隔 开 。 所 以 ， 生 成 的 IPv6 地 址 表 
示 形 式 称 为 冒号 十 六 进 制 表示 形式 。 


下 面 是 一 个 二 进 制 形 式 的 IPv6 地 址 ( 共 128 位 ) 示例 : 


0011111111111110:0010100100000000:1101000000000101:000000000 
0000000:0000001010101010:0000000011111111:1111111000101000:10011 
10001011010 


在 日 节 的 使 用 中 ，IPv6 地 址 不 是 以 二 进 制 来 表示 的 ， 而 是 以 十 六 
进 制 表示 的 (主要 也 是 为 了 书写 方便 ， 如 采 也 用 十 进 制 来 表示 的 话 ， 
这 个 十 进 制 数 就 会 很 大 ， 最 大 数 为 65535) 。 把 每 个 16 位 块 都 转换 成 十 
六 进 制 ， 相 邻 的 块 用 半角 冒号 隔 开 即 可 。 以 上 示例 转换 的 结果 为 ( 注 


3FFE:2900:D005:0000:02AA:00FF:FE28:9C5A 


导 零 省 略 表示 形式 


从 上 面 的 十 六 进 制 IPv6 地 址 来 看 ， 仍 然 相当 长 ， 仍 不 便于 书写 ， 
书写 时 也 容易 出 错 。 为 了 进一步 简化 IPv6 地 址 ， 在 IPv6 地 址 编 址 方案 中 
新 增 了 一 个 规定 ， 那 就 是 如 果 在 一 个 十 六 进 制 整 数 (也 就 是 一 个 地 址 
块 ) 中 高 位 为 0， 可 以 省 略 。 如 
3FFE:2900:D005:0000:02AA:00FF:FE28:9C5A 中 的 02AA， 则 就 可 以 写 
成 2AA; 00FF 可 以 直接 写成 FF。 如 果 整 个 地 址 块 都 是 0， 则 只 需要 写 一 
个 0 即 可 ， 如 上 面 示例 中 的 0000， 束 可 以 写成 0° 这 样 一 来 ， 这 个 示例 
就 可 以 进一步 简化 写成 : 


3FFF:2900:D005:0:2AA:FF:FE28:9C5A 


又 如 1080:0000:0000:0000:0008:0810:213C:123A 这 样 的 I[Pv6 地 址 ， 
采用 以 上 方案 后 就 可 直接 写成 1080:0:0:0:8:810:213C:123A 。 


3. 压 缩 零 表示 形式 


虽然 通过 前 面 介绍 的 前 导 零 省 略 法 已 对 IPv6 地 址 表示 形式 进行 了 
简化 ， 但 由 于 IPv6 地 址 规定 有 8 段 、128 位 之 多 ， 即 使 按 上 述 方 法 
把 “0” 的 写法 简化 了 ， 在 各 16 位 地 址 块 中 的 “0” 的 位 数 一 多 的 情况 下 也 会 
显得 有 点 奔 烦 ， 或 者 意义 不 大 。 为 了 进一步 简化 ， 又 导入 了 双 冒 号 的 
规则 。 即 可 以 用 双 冒 号 置换 地 址 中 连续 的 、 值 为 <0” 的 16 位 地 址 块 ( 转 
换 为 十 六 进 制 后 就 是 4 位 了 ， 下 同 ) ， 也 就 是 通常 所 说 的 双 冒 号 置换 


法 。 


如 上 面 的 1080:0:0:0:8:810:213C:123A 地 址 中 间 有 3 个 连续 的 地 址 块 
为 0， 此 时 可 将 3 个 连续 为 的 0 地 址 块 用 一 个 “:” 置 换 (包括 原来 连续 地 址 
块 间 的 冒号 ) 。 这 样 一 来 ， 上 面 示例 就 可 以 进一步 简写 成 : 
1080::8:810:213C:123A， 更 加 简化 了 。 


例如 ， 您 可 以 将 FE80:0:0:0:2AA:FF:FE9A:4CA2 的 IPv6 地 址 压缩 成 
FE80::2AA:FF:FE9A:4CA2; 可 以 将 FF02:0:0:0:0:0:0:2 的 IPv6 地 址 压缩 成 
FF02::2; 可 以 将 2000:0:0:0:0:0:0:1 的 IPv6 地 址 表示 为 2000::1。 
0:0:0:0:0:0:0:1 等 价 于 ::1; 0:0:0:0:0:0:0:0 等 价 于 :: 。 


注意 “ 双 冒 号 置换 法 ”中 的 双 冒 号 所 代表 的 值 为 0 的 连续 16 位 地 址 块 
个 数 不 限 ， 但 是 双 冒 号 在 一 个 地 址 中 只 能 使 用 一 次 ， 也 就 是 说 不 能 
复 使 用 它 来 替换 多 个 分 隔 的 、 连 续 地 址 块 中 的 多 个 0。 例 如 有 这 样 一 个 
IPv6 地 址 : 0:0:0:AB98:123C:0:0:0。 按 上 述 双 冒号 置换 原则 ， 可 缩写 
成 ::AB98:123C:0:0:0 或 0:0:0:AB98:123C::， 但 却 不 能 写 
成 :BA98:7654::， 因 为 这 样 在 一 个 地 址 中 两 次 使 用 冒号 置换 后 ， 您 就 无 


法 确定 每 个 “:" 代 表 多 少 位 零 。 


另外 , “ 双 冒 号 置换 法 ”中 的 双 冒 号 只 能 置换 连续 的 值 为 0 的 16 位 地 
址 块 ， 不 能 置换 非 连 续 的 值 为 0 的 多 个 16 位 地 址 块 。 如 
FE80:0:2AA:0:FF:0:FE9A:4CA2， 就 不 能 用 双 冒 号 置换 了 。 


还 有 ， 只 能 使 用 压缩 零 来 压缩 以 冒号 十 六 进 制 表示 形式 表示 的 一 
个 连续 的 ， 值 为 0 的 16 位 块 ， 不 能 对 16 位 块 的 一 部 分 的 0 进行 零 压 缩 。 
例如 ， 您 不 能 将 FF02:30:0:0:0:0:0:5 表 示 为 FF02:3::5， 因 为 在 这 个 书写 
格式 中 ， 把 作为 16 位 块 30 中 一 部 分 的 0 也 省 略 了 。 


在 压缩 后 的 地 址 中 要 确定 其 中 的 “::”( 双 冒号 ) 代表 了 多 少 个 0， 
可 以 计算 压缩 地 址 中 的 块 数 ， 用 8 减 去 此 数 ， 然 后 将 结果 乘 以 16 就 是 
了 。 例 如 ， 地 址 FF02::2 中 显示 只 有 两 个 地 址 块 〈“FF02” 块 和 “2? 块 ) ， 
这 意味 着 其 他 6 个 16 位 块 (总 共 是 8 个 地 址 块 ) 已 被 压缩 ， 也 就 是 说 这 
个 双 冒 号 代表 了 其 中 6 个 全 为 0 的 16 位 地 址 块 ， 一 共 是 6x16 位 =96 位 。 


最 后 总 结 一 下 IPv6 地 址 的 书写 规则 : 


1) 16 位 地 址 块 中 的 前 导 0 可 以 省 略 ， 如 果 16 位 全 为 0， 可 以 只 写 一 


个 0; 


2) 当 IPv6 地 址 中 有 多 个 连续 的 ， 值 为 0 的 16 位 地 址 块 时 ， 可 以 用 1 
个 双 冒 号 转换 这 些 连 续 的 0， 但 双 冒 号 在 一 个 IPv6 地 址 中 只 能 出 现 一 
次 ， 也 就 是 在 一 个 IPv6 地 址 只 能 用 一 个 双 冒 号 转换 一 个 连续 的 、 值 为 0 
的 16 位 地 址 块 。 


3) 不 能 用 双 冒 号 转换 属于 16 位 地 址 块 中 一 部 分 的 0， 即 使 是 地 址 
块 中 的 最 后 一 个 16 进 制 数 0。 


8.4.2 ”IPv6 地 址 中 的 二 进 制 数 与 十 六 进 制 转换 


因为 在 IPv6 地 址 中 使 用 的 是 二 进 制 或 者 十 六 进 制 ， 而 不 再 是 IPv4 地 
址 中 的 二 进 制 或 者 十 进 制 ， 所 以 这 束 涉 及 了 二 进 制 与 十 六 进 制 之 间 的 
转换 问题 。 这 在 第 1 章 已 介绍 过 。 在 此 仪 就 IPv6 地 址 中 的 二 进 制 与 十 六 
进 制 转换 方法 做 一 个 简单 介绍 。 其 实 束 是 给 出 了 4 位 二 进 制 所 对 应 的 十 
六 进 制 ， 如 表 8-2 所 示 (其 中 的 十 进 制 主要 是 为 了 方便 对 照 ) 。 


表 8-2 十进制、 十 六 进 制 和 二 进 制 之 间 的 转换 对 照 表 


- 进 制 
1000 
1001 
1010 
1011 
1100 
1101 
1110 
1111 


要 将 十 六 进 制 数 转换 成 二 进 制 数 ， 应 将 每 个 十 六 进 制 数字 转换 成 
对 等 的 4 位 二 进 制 数 字 。 例 如 ， 要 将 十 六 进 制 数 03D8 转 换 成 二 进 制 ， 应 
将 每 个 十 六 进 制 数字 (0、3、D 和 8) 分 别 转换 成 二 进 制 。 这 样 ， 
0x03D8 就 是 0000 0011 1101 1000 或 0000001111011000。 


要 将 二 进 制 数 转换 成 十 六 进 制 数 ， 应 从 低 序 位 开始 将 二 进 制 数 分 
割 成 包含 4 位 的 块 ， 节 后 不 足 4 位 时 在 前 面 以 “0 补足 。 然 后 ， 再 将 每 个 


包含 4 位 的 块 转换 成 与 其 相等 的 十 六 进 制 形式 。 例 如 ， 要 将 二 进 制 数 
110000110101110 转 换 成 十 六 进 制 ， 应 首先 将 整个 数 分 割 成 4 位 一 块 的 数 
字 块 ， 即 0110 0001 1010 1110 (第 一 个 0 是 补 的 ) 。 然 后 ， 将 每 块 转换 
成 十 六 进 制 数字 ， 即 61AE 。 


8.5”IPv6 地 址 类 型 


IPv6 协 议 主要 定义 了 三 种 地 址 类 型 : 单 播 地 址 (Unicast 
Address) 、 组 播 地 址 (Multicast Address) 和 任 播 地 址 (Anycast 
Address) 。 与 原来 在 IPv4 地 址 相 比 ， 新 增 了 “ 任 播 地 址 ”类 型 ， 取 消 了 
原来 IPv4 地 址 中 的 广播 地 址 ， 因 为 在 IPv6 中 的 广播 功能 是 通过 组 播 来 完 
成 的 。 


口 单 播 地 址 : 用 来 唯一 标识 一 个 接口 ， 关 似 于 IPv4 中 的 单 播 地 址 。 
发 送 到 单 播 地 址 的 数据 报 文 将 被 传送 给 此 地 址 所 标识 的 一 个 接口 。 


口 组 播 地 址 : 用 来 标识 一 组 接口 〈 通 党 这 组 接口 属于 不 同 的 和 
点 ) ， 类 似 于 IPv4 中 的 组 播 地 址 。 发 送 到 组 播 地 址 的 数据 报 文 被 传送 
给 此 地 址 所 标识 的 所 有 接口 。 


口 任 播 地 址 : 用 来 标识 一 组 接口 (通常 这 组 接口 属于 不 同 的 市 
点 ) 。 发 送 到 任 播 地 址 的 数据 报 文 被 传送 给 此 地 址 所 标识 的 一 组 接口 
中 距离 源 节 点 最 近 (根据 使 用 的 路 由 协议 进行 度量 ) 的 一 个 接口 。 


IPV6 地 址 类 型 是 由 地 址 前 级 部 分 来 确定 ， 主 要 地 址 类 型 与 地 址 前 
级 的 对 应 关系 如 表 8-3 所 示 。 有 关 IPv6 地 址 前 级 将 在 本 革 后 面 介绍 。 


表 8-3 1IPv6 地 址 类 型 与 地 址 前 缀 的 对 应 关系 


地 址 类 型 地 址 前 组 〈 二 进 制 ) IPv6 前 绥 标 识 
未 指定 地 址 ::/128 
mi 
单 播 地 址 链 路 本 地 地 址 FE80::/10 


站 点 本 地 地 址 FEC0::/10 
全 球 单 播 地址 其 他 形式 一 
ar | | oo 


任 播 地 址 从 单 播 地 址 空间 中 进行 分 配 ， 使 用 单 播 地 址 的 格式 


8.5.1 IPv6 单 播 地 址 


IPv6 单 播 地 址 与 IPv4 单 播 地 址 一 样 ， 都 只 标识 了 一 个 接口 。 为 了 适 
应 负载 平衡 系统 ，RFC 3513 人 允许 多 个 搂 口 使 用 同一 个 地 址 ， 只 要 这 些 
接口 作为 主机 上 实现 的 IPv6 的 单个 接口 出 现 。 整 个 IPv6 单 播 地 址 包括 以 
下 五 个 类 型 : 全 局 单 播 地 址 、 链 路 本 地 地 址 、 站 点 本 地 地 址 、 特 殊 地 
址 、 兼 容 性 地 址 。 下 面 分 别 予 以 介绍 。 


1. 全 局 单 播 地 址 


全 局 单 播 地 址 等 同 于 IPv4 中 的 公 网 地 址 ， 可 以 在 IPv6 Internet 上 进 
行 全 局 路 由 和 访问 。 这 种 地 址 类 型 允许 路 由 前 绥 的 聚合 ， 从 而 限制 了 
全 球 路 由 表 项 的 数量 。RFC3513 给 出 了 新 的 IPv6 全 局 单 播 地 址 通用 格 
式 ， 如 图 8-19 所 示 。 


16 位 志 64 位 | 


图 。 8-19 ”IPv6 全 局 单 播 地 址 结构 
全 局 单 播 地 址 包含 四 个 组 成 部 分 说 明 如 下 : 


口 001: 这 是 当前 可 分 配 的 全 局 地 址 的 地 址 前 经， 此 部 分 可 表示 为 


2000::/3。 


口 全 局 路 由 前 绥 : 指示 特定 组 织 的 站 点 的 全 局 路 由 前 级 。 前 面 三 
个 固定 位 与 本 部 分 的 45 位 全 局 路 由 前 绥 一 起 组 成 48 位 的 站 点 前 缀 ， 将 
其 分 配给 组 织 的 单个 站 点 。 分 配 了 此 前 弘之 后 ，IPvV6 Internet 上 的 路 由 
伏 将 与 该 48 位 前 级 匹配 的 IPv6 通 信和 转发 到 组 织 站 点 的 路 由 器 。 


口子 网 ID: 用 于 在 组 织 站 点 中 标识 子 网 ， 占 16 位 。 用 户 可 以 在 站 
点 内 使 用 这 16 位 来 创建 65 536 个 子 网 或 多 个 级 别 的 寻 址 层次 结构 以 及 有 
效 的 路 由 基础 结构 。 


口 接口 ID: 指示 站 点 内 特定 子 网 上 的 接口 ， 占 64 位 ， 这 部 分 对 应 
各 接口 的 64 位 IPv6MAC 地 址 ， 由 接口 目 动 分 配 。 其 实 也 可 不 用 MAC 地 
址 来 指定 接口 ID ， 人 为 编制 也 可 以 ， 下 同 。 


图 8-20 所 示 为 全 局 单 播 地 址 内 的 各 组 成 部 分 组 成 的 三 个 级 别 结 构 。 
公用 拓扑 是 提供 对 IPv6 Internet 的 访问 的 大 型 和 小 型 ISP 的 集合 ; 站 点 折 
扑 是 组 织 站 点 内 的 子 网 的 集合 ;接口 标识 符 用 于 标识 组 织 站 点 内 的 子 
网 上 的 特定 接口 。 


公共 拓扑 站 点 拓扑 。 ”接口 标识 符 
48 位 16 位 64 位 
< 一 > 一 一 一 一 > 


图 8-20 全 局 单 播 地 址 三 个 级 别 的 结构 


接口 DD 是 来 自 接口 的 链 路 层 地 址 (MAC 地 址 ; ， 但 这 里 的 MAC 地 
址 不 是 我 们 现在 IPv4 中 使 用 48 位 MAC 地 址 ， 而 是 在 IPv6 中 扩展 后 的 64 
位 MAC 地 址 一 一 EUI-64 MAC。 在 一 个 结 点 上 的 多 个 接口 上 可 以 使 用 相 
同 的 接口 ID， 只 要 他 们 连接 的 是 不 同 的 子 网 。 


对 于 所 有 单 播 地 址 ， 除 了 以 “000? 开 头 的 这 些 地 址 外 ， 接 口 ID (也 
就 是 IPv6 MAC 地 址 ) 必须 是 64 位 长 ， 而 且 要 符合 IPv6 改 进 的 EUI-64 格 
式 。64 位 EUI-64 地 址 是 由 电气 和 电子 工程 师 协 会 (IEEE) 定义 的 。 
EUI-64 地 址 或 者 被 指派 到 网 络 适配器 ， 或 者 从 IEEE 802 地 址 派生 得 
到 。 


IEEE EUI-64 地 址 代表 网 络 接口 寻 址 的 新 标准 。 其 中 的 “公司 ID” 部 
分 仍然 是 24 位 长 度 ， 但 “扩展 ID” 部 分 是 40 位 ， 从 而 为 网 络 适配器 制造 


商 创建 了 更 大 的 地 址 空间 ， 如 图 8-21 所 示 。 


24 位 | 24 位 


图 8-21 IPv6 中 的 EUI-64 地 址 结构 


IANA 负责 IPv6 地 址 空间 的 分 配 。 目 前 IANA 从 整个 全 局 单 播 地 址 
空间 (格式 前 级 为 001) 中 取 2001::/16 进 行 分 配 。IANA 指 定 的 注册 机 构 
把 2001:0600::/23 到 2001:0800::/23 段 IPv6 地 址 分 配给 欧洲 和 中 东 (包括 
中 国 ) 。 这 些 注册 机 构 再 从 IANA 得 到 的 地 址 空间 分 配 /32 前 级 给 IPv6 
ISP，IPv6 ISP 再 从 /32 前 级 中 分 配 /48 前 级 给 每 个 客户 。/48 前 级 的 地 址 空 
间 还 可 以 进一步 分 为 /64 前 缀 的 子 网 。 这 样 每 个 客户 最 大 可 以 有 65535 个 
子 网 。 


2.IPv6 本 地 单 播 地 址 


在 IPv6 中 ， 本 地 单 播 地 址 就 是 指 本 地 网 络 使 用 的 单 播 地 址 ， 也 就 
是 IPV4 地 址 中 经 常 所 说 的 局 域 网 专用 地 址 。 本 地 单 播 地 址 又 有 两 种 ， 
分 别 是 链 路 本 地 地 址 和 站 点 本 地 地 址 。 每 个 接口 上 至 少 要 有 一 个 链 路 
本 地 单 播 地 址 ， 另 外 还 可 分 配 任何 类 型 ( 单 播 、 任 播 和 组 播 ) 或 范围 
的 IPv6 地 址 。 


(1) 链 路 本 地 地 址 


链 路 本 地 地 址 仅 用 于 单个 链 路 (注意 ， 这 里 的 “ 链 路 ”就 相当 于 IPv4 
中 的 子 网 ) ， 不 能 在 不 同 子 网 中 路 由 。 结 点 使 用 链 路 本 地 地 址 与 同一 
个 链 路 上 的 相 邻 结 点 进行 通信 。 例 如 ， 在 没有 路 由 此 的 早 链 路 IPv6 网 
络 上 ， 主 机 使 用 链 路 本 地 地 址 与 该 链 路 上 的 其 他 主机 进行 通信 。 


链 路 本 地 地 址 等 效 于 169.254.0.0/16 网 段 的 自动 专用 IP 寻 址 
(APIPA) IPv4 地 址 〈 在 运行 Windows 系 统 的 计算 机 上 自动 配置 ) 。 令 P 
居 发 现 过 程 要 求 使 用 链 路 本 地 地 址 ， 该 地 址 始终 自动 配置 (也 就 是 无 
须 手 工 配置 ) ， 即 使 所 有 其 他 单 播 地 址 都 不 存在 也 是 如 此 。 图 8-22 所 示 


为 链 路 本 地 地 址 的 结构 。 


10 位 54 位 | 64 位 
1111 1110 10 000…000 接口 ID 


图 8-22 IPv6 链 路 本 地 地 址 结构 


从 图 中 可 以 看 出 ， 链 路 本 地 地 址 始终 以 “1111 1110 10”(FE80) 开 
头 。 后 面 紧 跟着 的 54 位 均 为 0， 最 后 的 64 位 是 用 来 标识 接口 ， 称 为 接口 
ID。 在 IPv6 单 播 地 址 中 的 接口 ID 用 来 标识 一 个 链 路 上 的 接口 ， 不 能 在 
同一 个 链 路 上 为 不 同 结 点 分 配 相同 的 接口 ID。 所 以 对 于 链 路 本 地 地 址 
的 前 缀 始终 是 FE80::/64。IPV6 路 由 絮 永 远 不 会 将 链 路 本 地 通信 转发 出 


该 链 路 。 


(2) 站 点 本 地 地 址 


站 点 本 地 地 址 相当 于 IPv4 中 的 局 域 网 专用 地 址 (如 本 章 前 面 介 绍 
的 10.0.0.0/8、172.16.0.0/12、192.168.0.0/16 这 三 个 局 域 网 专用 IPv4 地 址 
段 ) ， 仪 可 在 本 地 局 域 网 中 使 用 。 例 如 ， 没 有 与 IPv6 Internet 的 直接 路 
由 连接 的 专用 Intranet 可 以 使 用 不 会 与 全 局 地 址 冲突 的 站 点 本 地 地 址 。 
站 点 本 地 地 址 可 以 与 全 局 单 播 地 址 配合 使 用 ， 也 就 是 在 一 个 接口 上 可 
以 同时 配置 站 点 本 地 地 址 和 全 局 单 播 地 址 。 但 使 用 站 点 本 地 地 址 作为 
源 或 目的 地 址 的 数据 报 文 不 会 被 转发 到 本 站 点 (相当 于 一 个 私有 网 
络 ) 外 的 其 他 站 点 。 


站 点 本 地 地 址 的 地 址 格式 如 图 8-23 所 示 ， 前 48 位 总 是 固定 的 ， 即 总 
是 以 FEC0::/48 开 始 ， 因 为 站 点 本 地 地 址 的 前 10 位 固定 为 1111111011， 
后 面 紧 接 的 是 38 位 0。48 个 固定 位 之 后 ， 是 16 位 可 用 于 在 组 织 中 创建 子 
网 的 子 网 ID。 通 过 这 16 位 地 址 空间 ， 就 可 以 在 一 个 平滑 的 子 网 结构 中 
最 多 拥有 65 536 个 子 网 ， 或 者 细 分 子 网 ID 字段 的 高 位 ， 以 便 创 建 分 层 的 
和 可 聚合 的 路 由 结构 。 子 网 了 字段 之 后 ， 是 64 位 的 接口 ID 字段 ， 用 来 
标识 子 网 上 的 特定 接口 ， 也 是 对 应 接口 的 MAC 地 址 ， 与 前 面 介 绍 的 接 
口 ID 一 样 。 


| 10 位 38 位 < 16 位 | 64 位 | 
二 > < > 


Toul 000…:000 子 网 ID 接口 ID 


图 8-23 IPv6 站 点 本 地 地 址 结构 


经 验 之 谈 站 点 本 地 地 址 是 我 们 在 局 域 网 组 建 中 经 常 要 配置 的 
IPv6 地 址 ， 就 像 我 们 目前 在 了 Pv4 网 络 中 经 常 要 配置 局 域 网 专用 地 址 一 样 
(其 实 站 点 就 代表 局 域 网 ) ， 所 以 我 们 必须 要 记 住 站 点 本 地 地 址 的 基 
本 结构 ， 它 是 以 FEC0::/48 为 地 址 前 绥 的 ， 后 面 的 子 网 ID 我 们 在 设计 局 
域 网 时 就 应 设计 好 ， 为 不 同 的 子 网 分 配 连 续 或 不 连续 的 于 网 号 ， 接口 
ID 通常 是 通过 复制 对 应 接口 的 64 位 IPv6 MAC 地 址 得 到 的 。 


从 以 上 单 播 地 址 类 型 可 以 看 出 ，IPv6 具 有 分 级 地 址 模式 ， 也 就 是 
在 一 个 接口 上 可 以 同时 配置 应 用 于 内 部 链 路 、 站 点 (也 就 相当 于 内 部 
网 络 ) 和 Internet 公 网 连接 的 至 少 两 种 单 播 地 址 。 内 部 节点 与 Intermet 的 
连接 不 再 需要 经 过 IPv4 时 代 的 NAI 技 术 进 行 地 址 转换 ， 可 直接 为 每 台 需 
要 访问 Internet 的 主机 配置 全 局 单 播 地 址 。 


3. 内 租 IPv4 地 址 的 IPv6 单 播 地 址 


为 了 帮助 从 Ipv4 迁 移 到 IpPv6， 促 进 两 种 类 型 主机 的 并 存 ， 定 义 了 下 
列 地 址 。 


(1) IPv4 兼 容 地 址 


在 IPv6 的 转换 机 制 中 还 包括 了 一 种 通过 IPv4 路 由 接口 以 隧道 方式 动 
态 传递 IJPv6 包 的 技术 。 这 样 的 IPv6 结 点 会 被 分 配 一 个 在 低 32 位 中 带 有 全 


球 IPv4 单 播 地 址 的 IPv6 全 局 单 播 地 址 。 这 种 类 型 的 地 址 就 称 为 “与 IPv4 
兼容 和 IPv6 全 局 单 播 地 址 ”。 其 格式 如 图 8-24 所 示 。 注 意 这 里 的 IPv4 必 
须 是 全 球 唯一 的 公 网 IP 地 址 。 


80 位 16 位 32 位 


0000…000000 oo IPv4 地 址 | 


图 8-24 兼容 IPv4 的 IPv6 全 局 单 播 地 址 格式 


(2) IPv4 映 射 IPv6 本 地 单 播 地 址 


还 有 另 一 种 嵌入 IPv4 的 IPv6 地 址 ， 用 于 局 域 网 内 部 。 这 类 地 址 用 于 
把 IPv4 结 点 当 作 IPv6 结 点 。 这 种 类 型 的 地 址 称 为 IPv4 映 射 IPv6 本 地 单 播 
地 址 ， 格 式 如 图 8-25 所 示 。 


80 位 16 位 32 位 


0000…000000 TU IPv4 地 址 | 


图 8-25 ”映射 IPv4 的 IPv6 本 地 单 播 地 址 格式 


当 处 理 拥有 IPv4 和 IPv6 结 点 的 混合 环境 时 ， 可 以 使 用 IPv6 地 址 的 另 
一 种 形式 ， 即 x:x:x:x:x:x:d.d.d.d， 其 中 ，“x” 是 IPv6 地 址 的 96 位 高 位 顺序 
字 节 的 十 六 进 制 值 , “d" 是 32 位 低位 顺序 字 节 的 十 进 制 值 。 而 且 前 6 个 


16 位 地 址 块 (96 位 ) 间 是 用 冒号 分 隔 的 ， 后 面 的 4 个 8 位 地 址 块 (32) 
间 仍 用 小 圆 点 分 隔 。 例 如 : 0:0:0:0:0:0:10.1.2.3， 或 表示 成 ::10.1.2.3。 


(3) 6to4 地 址 


还 有 一 种 称 为 “6to4” 的 IPv6 地 址 ， 用 于 在 两 个 通过 Internet 同 时 运行 
IPv4 和 IPVv6 的 结 点 之 间 进 行 通信 。6to4 地 址 由 组 合 前 级 2002::/16 和 该 结 
点 的 32 位 公 网 IPv4 地 址 构成 ， 形 成 一 个 48 位 前 级 。 例 如 ，IPv4 地 址 
131.107.0.1，6to4 地 址 前 缀 是 2002:836B:1::/48。 当 然 ， 如 果 当 前 使 用 的 
是 动态 公 网 IPv4 地 址 ， 则 每 次 拨号 接 入 Internet 时 得 到 的 6to4 IPv6 是 不 
一 样 的 。 


4. 两 种 特殊 的 单 播 地 址 


在 IPv6 单 播 地 址 中 ， 还 有 两 种 特殊 的 单 播 地 址 : 


(1) 未 指定 地 址 


未 指定 地 址 (0:0:0:0:0:0:0:0 或 ::) 仅 用 于 表示 某 个 地 址 不 存在 。 它 
等 价 于 IPv4 示 指定 地 址 0.0.0.0。 未 指定 地 址 通常 被 用 做 尝试 验证 暂 定 地 
址 唯一 性 数据 包 的 源 地 址 。 未 指定 地 址 永远 不 会 指派 给 某 个 接口 或 被 
用 做 目标 地 址 。 


(2) 环 回 地 址 


环 回 地 址 (0:0:0:0:0:0:0:1 或 ::1) 用 于 标识 环 回 接口 ， 人 允许 节点 将 
数据 包 发 送 给 自己 。 它 等 价 于 IPv4 环 回 地 址 127.0.0.1。 发 送 到 环 回 地 址 
的 数据 包 永 远 不 会 发 送 给 某 个 链接 ， 也 永远 不 会 通过 IPV6 路 由 妖 转 
发 o 


8.5.2 IPv6 组 播 地 址 


对 于 IPv6 中 的 组 播 和 任 播 地 址 ， 新 的 RFC3513 标 准 中 并 没有 针对 原 
来 的 RFC2373 标 准 进行 太 多 改动 。IPv6 中 的 组 播 地 址 其 实 与 IPv4 中 的 组 
播 地 址 是 类 似 的 。 


IPv6 组 播 地 址 可 识别 多 个 接口 ， 对 应 于 一 组 接口 的 地 址 (通常 分 
属 不 同和 点) 。 发 送 到 组 播 地 址 的 数据 包 被 送 到 由 该 地 址 标识 的 每 个 
接口 。 使 用 适当 的 组 播 路 由 拓扑 ， 将 同 组 播 地 址 发 送 的 数据 包 发 送 给 
该 地 址 识别 的 所 有 接口 。 任 意 位 置 的 IPv6 节 点 可 以 侦 听 任意 IPv6 组 播 地 
址 上 的 组 播 通信 。IPv6 世 点 可 以 同时 侦 听 多 个 组 播 地 址 ， 也 可 以 随时 
加 入 或 离开 组 播 组 。 


IPV6 组 播 地 址 的 最 明显 特征 就 是 最 高 的 8 位 固定 为 1111 1111。IPv6 
地 址 很 容易 区 分 组 播 地 址 ， 因 为 它 总 是 以 FF 开始 的 。 除 了 地 址 前 组 
外 ， 组 播 地 址 还 包括 其 他 结构 ， 以 便 标识 它们 的 标志 、 作 用 域 和 组 播 
组 ， 如 图 8-26 所 示 。 


< 8 位 |< 4 位 a 4 位 112 位 


图 8-26 ”IPv6 组 播 地 址 结构 


组 播 地 址 结构 中 的 各 组 成 部 分 说 明 如 下 。 


1) 标志 : 表示 在 组 播 地 址 上 设置 的 标志 ， 占 4 位 。 其 实 前 3 位 均 
定 为 0， 只 有 最 后 1 位 具有 标志 意义 ， 这 一 位 记 作 “T”。 当 T 设 置 为 0 时 ， 
表示 该 组 播 地 址 是 由 互联 网 号 码 指派 机 构 IANA 水 久 指派 的 、 公 认 的 组 
播 地 址 ， 当 T 设 置 为 1 时 ， 表 示 该 组 播 地 址 是 临时 ( 非 永久 指派 ， 组 播 
地 址 。 


2) 作用 域 : 表示 进行 组 播 通 信 的 IPv6 网 络 的 作用 域 ， 也 就 是 本 次 
组 播 通信 的 范围 ， 占 4 位 ， 路 由 器 可 以 使 用 组 播 作用 域 来 确定 是 否 可 以 
转发 组 播 通信 。 在 RFC 2373 中 定义 的 作用 域 如 表 8-4 所 示 。 


表 8-4 RFC2373 定义 的 IPv6 组 播 地 址 作用 域 


字段 什 作用 域 作用 域 
| 接口 本 地 域 组 织 本 地 域 
9 


本地 分 
果 贸 E 全 局 域 
保留 


例如 ， 使 用 组 播 地 址 FF02::2 的 通信 具有 链 路 本 地 作用 域 ， 因 为 它 
的 第 四 个 十 六 进 制 位 《作用 域 位 ) 的 值 为 2。IPv6 路 由 器 永远 不 会 将 此 
通信 转发 到 本 地 链 路 以 外 。 


3) 组 ID: 用 于 标识 组 播 组 ， 并 且 在 作用 域 中 是 唯一 的 ， 占 112 
位 。 永 久 指派 的 组 ID 独立 于 作用 域 ， 临 时 组 ID 仅 与 特定 的 作用 域 有 


为 了 标识 接口 本 地 作用 域 和 链 路 本 地 作用 域 的 所 有 下 点 ， 定 义 了 
下 列 组 播 地 址 : 


口 FF01::1 (表示 包括 接口 本 地 作用 域 所 有 市 点 的 组 播 地 址 ) : 


口 FF02::1 《表示 包括 链 路 本 地 作用 域 所 有 闻 点 的 组 播 地 址 ) 。 


为 了 标识 接口 本 地 作用 域 、 链 路 本 地 作用 域 和 站 点 本 地 作用 域 的 
所 有 路 由 器 ， 定 义 了 下 列 组 播 地 址 : 


DFF01::2 (表示 包括 接口 本 地 作用 域 所 有 路 由 器 的 组 播 地 址 )， 
口 FF02::2 (表示 包括 链 路 本 地 作用 域 所 有 路 由 器 的 组 播 地 址 ) ，; 
口 FF05::2 (表示 包括 站 点 本 地 作用 域 所 有 路 由 器 的 组 播 地 址 ) 。 


因为 在 组 DD 中 长 达 112 位 ， 所 以 可 能 有 2 个 组 ID。 又 因为 IPv6 组 
播 地 址 在 数据 链 路 层 封 泛 时 将 被 映射 到 以 太 网 组 播 MAC 地 址 ， 所 以 
RFC 2373 建 议 从 IPv6 组 播 地址 的 低 阶 32 位 指派 组 ID， 并 将 剩余 的 原始 
组 ID 位 设置 为 0， 如 图 8-27 所 示 。 通 过 在 组 ID 中 只 使 用 低位 32 位 ， 每 个 
组 ID 映射 到 唯一 的 以 太 网 组 播 MAC 地 址 。 


8 位 4 位 4 位 80 位 32 位 


1111 1111 | 标志 作用 域 000…000 组 ID 


图 8-27 使 用 32 位 组 ID 的 建议 IPv6 组 播 地 址 


8.5.3 IPv6 任 播 地 址 


任 播 地 址 是 IPv6 协 议 中 的 全 新 概念 ， 与 上 面 的 组 播 地 址 既 有 相似 
之 处 ， 又 有 本 质 区 别 。 一 个 IPv6 任 播 地 址 与 组 播 地 址 一 样 也 可 以 识别 
多 个 接口 ， 对 应 一 组 接口 的 地 址 。 大 多 数 情 况 下 ， 这 些 接口 属于 不 同 
的 证 点。 但是， 与 组 播 地 址 不 同 的 是 ， 发 送 到 任 播 地 址 的 数据 包 被 送 
到 由 该 地 址 标识 的 其 中 一 个 接口 。 由 于 使 用 任 播 地 址 的 标准 尚 在 不 断 
完善 中 ， 所 以 目前 很 少 有 系统 文 持 任意 播送 。 


通过 合适 的 路 由 拓扑 ， 目 的 地 址 为 任 播 地 址 的 数据 包 将 被 发 送 到 
单个 接口 (该 地 址 识别 的 最 近 接口 ， 最 近 接 口 定 义 的 根据 是 因为 路 由 
距离 最 近 ) ， 而 组 播 地 址 用 于 一 对 多 通信 ， 发 送 到 多 个 接口 。 一 个 任 
播 地 址 必须 不 能 用 作 IPv6 数 据 包 的 源 地 址 ;也 不 能 分 配给 IPv6 主 机 ， 仅 
可 以 分 配给 IPv6 路 由 器 。 


目前 ， 任 播 地 址 只 作为 目标 地 址 使 用 ， 并 且 只 分 配给 路 由 器 。 任 
播 地 址 在 单 播 地 址 空间 之 外 分 配 ， 任 播 地 址 的 作用 域 是 分 配 的 任 播 地 
址 所 属 的 单 播 地 址 类 型 的 作用 域 。 


子 网 -路 由 絮 任 播 地 址 已 预定 义 ， 并 且 是 必需 的 。 该 地 址 通过 给 害 
接口 的 子 网 前 级 创建 。 若 要 构造 子 网 -路 由 器 任 播 地 址 ， 子 网 前 级 中 的 
位 固定 为 相应 的 值 ， 其 他 位 则 设置 为 0， 如 图 8-28 所 示 。 任 播 地 址 中 的 


64 位 子 网 前 绥 是 用 来 标识 特定 的 链 路 。 后 面 的 64 位 是 接口 ID， 语 法 与 


单 播 地 址 一 样 ， 只 是 把 接口 ID 部 分 全 部 置 0。 


64 位 64 位 
子 网 前 级 0000…0000 


图 8-28 IPv6 任 播 地 址 格式 


发 到 子 网 -路 由 右 任 播 地 址 的 数据 包 将 传送 到 子 网 中 的 一 个 路 由 器 
上 。 所 有 路 由 瑚 的 所 有 接口 都 要 能 文 持 该 子 网 的 任 播 地 址 。 子 网 -路 由 
器 任 播 地 址 主要 用 于 需要 与 任何 一 个 路 由 器 通信 的 应 用 节点 ， 如 一 个 
网 络 中 有 几 个 网 络 出 口 ， 此 时 在 网 络 中 的 应 用 服务 器 上 配置 好 任 播 地 
址 ， 束 可 以 在 任 一 时 刻 动态 选择 其 中 一 个 出 口 与 外 网 连接 。 


8.5.4 ”IPv6 主 机 和 路 由 兹 地 址 


由 于 IPv6 地 址 数 过 于 庞大 ， 加 上 IPv6 地 址 类 型 又 比较 复杂 ， 所 以 
了 解 实 际 的 网 络 配置 中 主机 和 网 络 设备 配置 的 ITPv6 地 址 有 哪些 就 显得 
非常 重要 了 “。 安 装 单个 网 络 适 配器 的 IPv4 主 机 ， 有 一 个 指派 给 该 适 配 
器 的 单独 的 IPv4 地 址 。 但 是 ，IPv6 主 机 通常 有 多 个 IPv6 地 址 ， 即 使 只 
有 单一 的 接口 。 


IPv6 主 机 通常 在 逻辑 上 是 多 主机 的 ， 因 为 它们 至 少 有 两 个 用 于 接 
收 数据 包 的 地 址 ， 一 个 为 用 于 本 地 链接 通信 的 链 路 本 地 地 址 ， 一 个 为 
可 路 由 的 站 点 本 地 地 址 或 全 局 单 播 地 址 。 


在 IPv6 主 机 上 可 以 指派 以 下 单 播 地 址 : 

口 用 于 每 个 接口 的 链 路 本 地 地 址 ; 

口 用 于 每 个 接口 的 站 点 本 地 地 址 ， 或 一 个 或 多 个 全 局 单 播 地 址 ; 
口 用 于 回环 接口 的 回环 地 址 (::1) 。 

另外 ， 每 个 主机 都 在 以 下 组 播 地 址 侦 听 通信 : 


口 作用 域 为 "节点 本 地 ”的 所 有 节点 组 播 地 址 (FF01::1) ; 


口 作用 域 为 “ 链 路 本 地 ”的 所 有 市 点 组 播 地 址 (FF02::1) ; 


口 每 个 接口 上 用 于 每 个 单 播 地 址 请 求 的 节点 地 址 ; 


口 每 个 接口 上 已 加 入 组 的 组 播 地址 。 


在 IPv6 路 由 器 上 可 指派 以 下 单 播 地 址 : 


口 用 于 每 个 接口 的 链 路 本 地 地 址 ; 


口 用 于 每 个 接口 的 站 点 本 地 地 址 ， 或 一 个 或 多 个 全 局 单 播 地 址 ; 


口 用 于 回环 接口 的 回环 地 址 (::1) 。 


IPV6 路 由 器 可 指派 有 以 下 任 播 地 址 : 


口 用 于 每 个 子 网 的 子 网 路 由 器 任 播 地 址 ; 


口 其 他 任 播 地 址 (可 选 ) 。 


男 外 ， 每 个 路 由 右 将 在 以 下 组 播 地 址 侦 听 通信 : 


口 作用 域 为 “节点 本 地 ”的 所 有 市 点 组 播 地 址 (FF01::1) ; 


口 作用 域 为 “节点 本 地 ”的 所 有 路 由 器 地 址 (FF01::2) ; 


口 作用 域 为 " 链 路 本 地 ”的 所 有 节点 组 播 地 址 (FF02::1) ; 


口 作用 域 为 " 链 路 本 地 ”的 所 有 路 由 器 组 播 地 址 (FF02::2) : 


口 作用 域 为 "站 点 本 地 ”的 所 有 路 由 器 组 播 地 址 (FF05::2) : 


口 每 个 接口 上 用 于 每 个 单 播 地 址 的 请 求 节 点 地 址 ; 


口 每 个 接口 上 已 加 入 组 的 组 播 地址 。 


从 以 上 可 以 看 出 ， 站 点 本 地 地 址 和 全 局 单 播 地 址 不 能 同时 配置 ， 
如 果 主 机 或 路 由 器 接口 要 与 Internet 和 连接 ， 就 需要 力 它 配置 全 局 单 播 地 
由 


8.5.5 _ IPv6 地 址 前 缀 表示 形式 


你 可 以 像 IPv4 用 地 址 前 级 表示 地 址 范围 一 样 ，IPv6 也 将 地 址 范围 
表示 为 地 址 前 级 。 


IPv6 地 址 前 缀 的 基本 表示 形式 为 ， 地 址 前 级 /前 级 长 度 。 地 址 前 级 
是 指 地 址 中 最 左边 那些 固定 不 变 的 部 分 采用 原来 的 值 ， 而 可 变 部 分 置 0 
得 到 ， 这 与 IPv4 地 址 中 的 地 址 前 绥 获 取 方 法 是 一 样 的 。 前 绥 长 度 瓯 是 
地 址 前 缀 部 分 的 位 数 。 与 IPv4 地 址 前 级 表示 形式 一 样 ， 在 前 缀 符 
号 “/* 前 一 定 要 是 一 个 完整 的 IPv6 地 址 ， 否 则 会 产生 异 义 。 


如 要 描述 像 122AB00000000CD3 这 样 一 个 60 位 地 址 前 级 ， 则 可 以 有 
以 下 三 种 表示 形式 (不 同 IPv6 地 址 可 以 表示 的 形式 也 不 一 样 ， 这 个 地 
址 的 三 种 前 缀 表示 形式 其 实 就 是 一 种 ， 只 是 后 两 种 采用 了 压缩 零 规 
则 ) : 


U12AB:0000:0000:CD30:0000:0000:0000:0000/60; 


L112AB::CD30:0:0:0:0/60; 


12AB:0:0:CD30::/60 。 


但 是 以 下 三 种 表示 形式 束 不 行 了 : 


口 12AB:0:0:CD3/60: 这 是 因为 没有 补 齐 整个 地 址 的 128 位 ， 前 导 0 
可 以 不 写 ， 但 后 面 的 0 不 能 省 略 。 


口 12AB::CD30/60: 仅 从 这 种 格式 来 展开 的 话 ， 这 个 地 址 束 成 了 
12AB:0000:0000:0000:0000:000:0000:CD30， 而 不 是 原来 的 地 址 格式 
本 o 


口 12AB::CD3/60: 仅 从 这 种 格式 来 展开 的 话 ， 这 个 地 址 就 成 了 
12AB:0000:0000:0000:0000:000:0000:0CD3， 也 不 是 前 面 的 那个 地 址 格 
式 了 。 


在 为 IPv6 主 机 、 路 由 器 配置 IPv6 地 址 时 要 注意 前 面 列 出 的 对 应 类 
型 ， 同 时 要 注意 的 是 在 一 个 接口 上 可 以 同时 配置 多 个 不 同类 型 的 IPv6 
地 址 ， 分 别 用 于 本 地 链 路 、 本 地 站 点 和 公 网 路 由 。 但 在 配置 这 些 IPv6 
地 址 时 ， 要 注意 对 应 类 型 的 地 址 前 级 格式 ， 不 能 配 错 。 


8.6 ”IPv6 地 址 自动 配置 


在 本 章 前 面 束 已 提 人 a 到，IPv6 地 址 具有 目 动 配置 功能 ， 所 以 虽然 它 
长 达 128 位 ， 但 配置 起 来 并 不 是 很 复杂 。IPv6 最 有 用 的 方面 古 在 不 使 用 
全 状态 配置 协议 (例如 IPv6 的 动态 主机 配置 协议 DHCPv6) 的 情况 下 
能 够 对 目 己 进行 目 动 配置 。 默 认 情 况 下 ，IPv6 主 机 可 以 通过 操作 系统 
目 动 为 每 个 接口 配置 的 一 个 链 路 本 地 地 址 来 进行 本 地 寻 址 和 邻居 发 
现 。 通 过 使 用 路 由 妖 发 现 功 能 ， 主 机 也 可 以 确定 路 由 器 的 地 址 、 附 加 
地 址 和 其 他 配置 参数 。 


8.6.1 _ IPv6 地 址 目 动 配置 的 类 型 


IPv6 有 以 下 三 种 自动 配置 类 型 ， 对 于 所 有 的 自动 配置 类 型 ， 所 配 
置 的 地 址 均 是 链接 本 地 地 址 。 


(1) 无 状态 的 自动 配置 


这 种 IPv6 地 址 的 目 动 配置 是 基于 路 由 器 公告 消 轧 的 接收 。 这 些 消 
轧 包括 无 状态 地 址 前 缀 ， 并 要 求 主 机 不 使 用 全 状态 地 址 配置 协议 。 


IPv6 无 状态 地 址 配置 协议 是 目前 广泛 采用 的 IPv6 地 址 目 动 配置 方 
式 。 配 置 了 该 协议 的 主机 只 需 相 邻 路 由 器 开启 IPv6 路 由 公告 功能 ， 即 


可 以 根据 公告 报 文 包含 的 前 缀 信息 自动 配置 本 机 地 址 。 但 无 状态 地 址 
配置 方案 中 路 由 器 并 不 记录 所 连接 的 IPv6 主 机 的 具体 地 址 信息 ， 可 管 
理性 差 。 而 且 当 前 无 状态 地 址 配置 方式 不 能 使 IPv6 主 机 获取 DNS 服务 
器 的 地 址 和 域名 等 配置 信息 ， 在 可 用 性 上 有 一 定 缺陷。 对 于 互联 网 服 
务 提供 商 (ISP) 来 说 ， 也 没有 相关 的 规范 指明 如 何 向 路 由 器 自动 分 配 
IPv6 前 级 ， 所 以 在 部 署 IPv6 网 络 时 ， 只 能 采用 手动 配置 的 方法 为 路 由 
交换 设备 配置 IPv6 地 址 。 


(2) 监控 状态 的 自动 配置 


监控 状态 的 自动 配置 是 基于 全 状态 地 址 配置 协议 的 使 用 (例如 
DHCPv6) 来 获取 地 址 和 其 他 配置 选项 的 。 当 主机 收 到 不 包括 地 址 前 
级 的 路 由 絮 公 告 消 轧 ， 并 要 求 主机 使 用 全 状态 地 址 配置 协议 时 ， 将 使 
用 全 状态 地 址 配置 。 当 本 地 链 路 上 没有 路 由 器 存在 时 ， 主 机 也 使 用 全 
状态 地 址 配置 协议 。 


DHCPv6 是 动态 主机 配置 协议 (DHCP) 的 IPv6 版 本 ， 协 议 基本 规 
范 由 RFC3315 定 义 。 相 对 于 IPv6 无 状态 地 址 自动 配置 协议 ，DHCPv6 属 
于 一 种 有 状态 地 址 自动 配置 协议 。 在 有 状态 地 址 配置 过 程 中 ， 
DHCPv6 服 务 器 分 配 一 个 完整 的 IPv6 地 址 给 主机 ， 并 提供 DNS 服务 器 
地 址 和 域名 等 其 他 配置 信息 ， 这 中 间 可 能 通过 中 继 代 理 转交 DHCPv6 
报 文 ， 而 且 最 终 服务 器 能 把 分 配 的 ITPv6 地 址 和 客户 端的 绑 定 关系 记录 
在 案 ， 从 而 增强 了 网 络 的 可 管理 性 。 


DHCPv6 服 务 器 也 能 提供 无 状态 DHCPv6 服 务 ， 即 DHCPv6 服 务 器 
不 分 配 IPv6 地 址 ， 仅 需 向 主机 提供 DNS 服务 器 地 址 和 域名 等 其 他 配置 
言 息 ， 主 机 IPv6 地 址 仍然 通过 路 由 器 公告 方式 自动 生成 ， 这 样 配合 使 
用 就 弥补 了 IPv6 无 状态 地 址 自动 配置 的 缺陷 。DHCPvV6 协 议 还 提供 了 
DHCPV6 前 级 代理 的 扩展 功能 ， 上 游 路 由 器 可 以 自动 为 下 游 路 由 器 分 
派 地 址 前 级 ， 从 而 实现 了 层次 化 网 络 环 境 中 IPv6 地 址 的 自动 规划 ， 解 
决 互联 网 提供 商 (ISP) 的 IPv6 网 络 部 署 问 题 。 


(3) 两 者 兼备 的 自动 配置 


这 种 目 动 配置 类 型 是 根据 路 由 器 公告 消 轧 的 回执 进行 配置 。 这 些 
请 恩 包 括 无 状态 地 址 前 级， 并 要 求 主机 使 用 全 状态 地 址 配置 协议 。 


8.6.2 ”自动 配置 过 程 


IPV6 广 点 的 链 路 本 地 地 址 目 动 配置 过 程 如 下 : 


1) 基于 链 路 本 地 前 级 FE80::/64 和 64 位 接口 标识 组 合成 暂 定 的 链 路 
本 地 地 址 。 


2) 执行 重复 地 址 检测 ， 以 便 验 证 暂 定 链 路 本 地 地 址 的 唯一 性 


3) 如 果 重 复 地 址 检测 失败 〈 也 就 是 链 路 中 有 与 本 暂 定 链 路 本 地 地 
址 一 样 的 地 址 ) ， 则 必须 对 该 节点 执行 手动 配置 。 


4) 如 果 重 复 地 址 检测 成 功 (也 就 是 链 路 中 没有 与 本 暂 定 链 路 本 地 
地 址 一 样 的 地 址 ) ， 则 此 暂 定 链 路 本 地 地 址 将 是 唯一 的 和 有 效 的 ， 并 
为 该 接口 初始 化 链 路 本 地 地 址 。 


对 于 IPv6 主 机 地 址 目 动 配置 ， 在 市 点 完成 目 动 配置 过 程 后 ， 还 需 
继续 如 下 过 程 : 


1) 主机 发 送 路 由 器 请 求 消息 。 


2) 如 果 没 有 收 到 路 由 器 公告 消息 ， 则 主机 将 使 用 全 状态 地 址 配置 
协议 来 获取 地 址 和 其 他 配置 参数 。 


3) 如 果 收 到 路 由 器 公告 消息 ， 将 在 主机 设置 消息 中 包括 配置 信 


4) 对 于 每 个 无 状态 自动 配置 ， 使 用 以 下 方法 来 验证 自动 配置 的 地 
址 : 


口 使 用 地 址 前 缀 和 适当 的 64 位 授 口 标识 派生 出 的 暂 定 地 址 。 
口 使 用 重复 地 址 检测 来 验证 暂 定 地 址 的 唯一 性 


如 有 果 正 在 使 用 该 暂 定 地 址 ， 则 不 能 为 该 接口 初始 化 此 地 址 ， 如 果 
没有 使 用 该 暂 定 地 址 ， 则 初始 化 该 地 址 ， 包 括 基于 路 由 器 公告 消息 中 
包括 的 信息 来 设置 有 效 状 态 和 前 克 状 态 的 生存 时 间 ;， 如 琳 在 路 由 器 公 
告 消息 中 指定 ， 则 主机 将 使 用 全 状态 地 址 配置 协议 来 获取 附加 地 址 或 
配置 参数 。 


图 8-29 所 示 的 是 一 台 Windows 7 主机 自动 获得 的 四 个 IPv6 地 址 。 其 
中 第 一 个 以 2002 开 头 的 IP 地 址 是 一 个 6to4 IPv6 地 址 ， 第 二 个 是 本 地 站 
点 IPv6 地 址 ， 相 当 于 局 域 网 IPv6 地 址 ; 第 三 个 是 临时 IPv6 地 址 ， 即 动 
态 拨号 接 入 时 从 ISP 中 获得 的 临时 IPv6 地 址 ， 可 以 看 出 它 也 是 一 种 6to4 
地 址 ;第 四 个 是 本 地 链接 IPv6 地 址 ， 仅 于 本 地 链 路 通信 ， 后 面 
的 “%” 跟 的 是 逻辑 接口 号 。 


: 29082:71f90:92f:b:9d8d :eafc:823b:3905 
: fecB::b:9d0d:eafc:823h:3705xX2 

: 2882:71f8:92f:b:3533:2687:5f49:77d6 
: fe80: :9d0d:eafc:823b:3905x11 

: 192.168.1.108 

3 255 .255 .255 .有 


: fe80::4599:83398:d494:372hbx13 
: 192.168.112.1 
: 255 .255.255. LL 


8-29 一 个 节点 上 获得 的 四 个 IPv6 地 址 


第 9 划 ”路 由 协议 及 工作 原理 


本 关内 容 相对 较为 复杂 ， 对 于 初学 者 来 说 ， 可 暂时 作为 选 学 内 


在 第 7 章 我 们 已 介绍 了 网 络 层 的 主要 功能 和 主要 路 由 算法 ， 本 章 将 
介绍 目前 常见 的 几 种 动态 路 由 协议 (包括 RIP、OSPF、IS-IS 和 BGP) 
的 基础 知识 、 所 采用 的 路 由 算法 工作 原理 、 主 要 路 由 消息 及 报 文 格 
式 。 其 中 最 重要 的 是 使 用 这 些 路 由 协议 的 基本 网 络 结构 、 路 由 表 基 本 
生成 原理 ， 以 及 不 同 路 由 消息 报 文 的 用 途 和 基本 报 文 格式 。 


为 了 把 复杂 的 内 容 讲解 得 尽 可 能 通俗 易 履 ， 本 章 仍 采用 前 面 各 章 
的 通俗 介绍 方法 ， 里 面 不 仅 有 大 量 的 比喻 ， 还 包括 了 大 量 的 示例 、 图 
表 。 


9.1 ”RIP 路 由 协议 


RIP (Routing Information Protocol， 路 由 信息 协议 ) 是 应 用 较 早 、 
使 用 较 普 遍 的 内 部 网 关 协 议 (Interior Gateway Protocol，IGP) ， 适 用 
于 小 型 同类 网 络 的 一 个 自治 系统 (AS) 内 的 路 由 信息 的 传递 。RIP 协 议 
采用 距离 矢量 (也 就 是 用 距离 作为 路 由 变量 路 由 算法 ， 使 用 跳 数 
( 即 Hop) 来 衡量 到 达 目 标 地 址 的 路 由 距离 ， 且 最 大 跳 数值 仅 为 15。 


RIP 协 议 现 在 有 两 个 版 本 ， 即 RIPV1 和 RIPV2， 新 版 本 RIPV2 支 持 纯 
文本 和 MD5 刁 份 认 证 、 路 由 汇总 、 无 类 别 域 间 路 由 (Classless 
Interdomain Routing，CIDR) 和 可 变 长 度 子 网 掩 码 (Variable-Length 
Subnet Masks，VLSM) 。 有 关 CIDR 和 VLSM 请 参见 本 书 第 8 章 。 


9.1.1 ”RIP 路 由 度量 机 制 


每 一 种 路 由 协议 都 想 通 过 菏 一 个 参考 变量 来 实现 最 住 路 由 的 计 
算 ， 也 就 是 每 一 种 路 由 协议 都 有 目 己 的 路 由 度量 机 制 。 不 同 的 路 由 协 
议 所 采取 的 路 由 度量 机 制 是 不 一 样 的 ， 这 取决 于 各 上 自 所 采用 的 路 由 算 


法 。 
1 理解 < 跳 数 " 


RIP 协 议 采 用 的 是 “距离 天 量 ” 路 由 算法 ， 是 仅 以 “距离 "作为 度量 标 
准 的 ， 也 就 是 路 由 的 “距离 ”是 RIP 路 由 的 度量 。 但 要 注意 的 是 ， 这 
里 “距离 ”不 是 指 实际 的 通信 线路 长 度 ， 也 不 是 两 个 网 络 或 者 两 台 主 机 
相距 的 物理 距离 ， 而 是 指 除 源 网 络 所 连接 的 路 由 器 外 ， 到 达 目 的 网 络 
的 整 条 路 由 路 径 中 所 经 过 的 路 由 器 数 ， 即 跳 数 (Hop Count) 。 


假设 在 图 9-1 所 示 的 网 络 中 ， 四 个 路 由 器 都 运行 了 RIP 协 议 。 现 在 
要 配置 从 PC1 所 在 网 络 到 达 PC2 所 在 网 络 的 RIP 路 由 ， 则 跳 数 就 是 3 (R1 
不 算 ， 其 他 每 个 路 由 器 算 一 跳 ) 。 但 是 我 们 看 一 下 ， 这 四 个 路 由 器 所 


连接 的 网 络 数 达 到 了 5 个 〈 从 1.1.1.0/24 到 5.1.1.0/24) ， 当 然 这 还 只 是 最 
简单 的 网 络 了 ， 因 为 每 个 路 由 器 还 可 以 连接 多 个 网 络 。 但 在 同一 个 路 
由 器 上 直接 连接 的 多 个 网 络 彼此 间 的 度量 值 为 0， 因 为 它们 是 直 连 路 
由 o 
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图 9-1 RIP 路 由 跳 数 计算 示例 
2. 度 量 更 新 规则 


RIP 路 由 融 采 用 完整 路 由 表 更 新 方式 ， 也 就 是 每 个 RIP 路 由 器 会 把 
目 己 的 路 由 表 发 给 相 邻 的 RIP 路 由 器 ， 以 此 来 进行 彼此 的 路 由 表 更 新 。 
总 体 来 说 ， 它 遵循 以 下 几 个 基本 原则 : 


口 路 由 表 项 每 经 过 一 次 邻居 之 间 的 传递 ， 其 度量 值 加 1 (最 大 值 为 
15， 下 同 ) 。 


在 如 图 9-1 所 示 的 网 络 中 ，R1 路 由 絮 把 它 所 连接 的 1.1.1.0/24 网 络 癌 
R2 通 告 ， 这 时 在 R2 上 到 达 1.1.1.0/24 网 络 的 度量 为 1， 当 R2 再 把 它 获 取 
的 到 达 1.1.1.0/24 网 络 的 路 由 发 给 R3 时 ，R3 上 到 达 1.1.1.0/24 网 络 的 度量 
就 变 为 2， 而 当 R3 把 获取 的 到 达 1.1.1.0/24 网 络 的 路 由 发 给 R4 时 ，R4 上 
到 达 1.1.1.0/24 网 络 的 度量 就 变 为 3。 


口 收 到 新 路 由 表 项 时 ， 在 路 由 表 中 汪 、 加 新 的 路 由 表 项 ， 其 度量 是 
在 接收 的 路 由 表 项 度量 基础 上 加 1， 同 时 在 新 添加 的 路 由 表 项 中 标注 其 
下 一 跳 地 址 就 是 发 送 路 由 更 新 的 邻 大 路 由 器 的 接口 。 


如 图 9-1 所 示 的 示例 中 ， 假 设 R4 在 收 到 来 自 R3 的 路 由 表 更 新 时 发 现 
包含 了 一 条 到 达 6.1.1.0/24 网 络 的 新 路 由 表 项 ， 并 且 其 度量 为 2， 这 时 R3 
就 会 在 自己 的 路 由 表 中 添加 这 条 新 的 路 由 表 项 ， 并 且 设 置 度量 为 3 

(2+1) ,“ 下 一 跳 地 址 ?为 R3 与 R4 相 连 的 那个 接口 了 地 址 。 


口 收 到 原 有 路 由 表 项 的 路 由 更 新 时 ， 先 对 有 更 新 的 路 由 表 项 的 度 
量 加 1， 然 后 与 对 应 的 路 由 表 项 中 原 度 量 进行 比较 ， 仅 接收 度量 值 更 小 
或 相等 的 更 新 ， 忽 略 度量 值 比 原来 的 值 更 大 的 路 由 更 新 。 


假设 在 图 9-1 中 ，R2 中 原 有 的 路 由 表 项 如 图 9-2 所 示 ， 现 又 收 到 来 日 
R3 的 如 图 9-3 所 示 的 路 由 更 新 《局 用 了 水 平分 割 功能 后 就 不 会 出 现 这 样 
的 更 新 了 ) 。 
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| 


图 9-2 R2 路 由 右上 原来 的 路 由 表 


目的 网 络 一 跳 
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图 9-3 R2 收 到 来 自 R3 的 路 由 更 新 


对 于 R2 来 说 ， 在 收 到 来 自 R3 的 路 由 更 新 后 ， 首 先 对 图 9-3 所 示 的 各 
路 由 表 项 的 度量 加 1， 结 果 得 到 的 路 由 表 项 如 图 9-4 所 示 。 对 比 图 9-4 和 
图 9-2 可 以 看 出 ， 到 达 2.1.1.0 网 络 和 3.1.1.0 网 络 的 度量 值 比 原 来 的 还 大 ， 
所 以 忽略 更 新 ， 而 到 达 4.1.1.0 网 络 和 5.1.1.0 网 络 的 度量 值 是 相等 的 ， 进 
行路 由 表 项 更 新 ， 所 以 最 终 R2 上 的 路 由 表 还 是 图 9-2 所 示 那 样 。 


图 9-4 R2 对 收 到 的 路 由 更 新 表 项 度量 值 加 1 后 的 路 由 表 


如 果 一 个 接口 连接 的 网 络 没 有 指定 (也 就 是 没有 宣告 所 直接 连接 
的 网 络 ) ， 则 它 不 会 在 任何 RIP 更 新 中 被 通告 。 如 图 9-1 中 ， 在 R1 的 配 


置 中 没有 宣告 它 所 连接 的 1.1.1.0/24 网 络 ， 则 其 他 路 由 器 上 也 就 没有 到 
达 这 个 网 络 的 RIP 路 由 表 项 ， 如 果 这 些 路 由 器 仅 局 用 了 RIP 协 议 ， 且 不 
配置 静态 路 由 ， 则 其 他 路 由 妖 也 就 不 能 到 达 1.1.1.0/24 这 个 网 络 了 。 


当然 ， 到 达 同 一 目的 网 络 ， 也 可 能 距离 是 一 样 的 ， 这 时 束 可 能 存 
在 同一 目的 网 络 的 两 条 RIP 路 由 表 项 ， 可 以 实现 负载 均衡 。 


9.1.2 RIP 路 由 更 新 机 制 


RIP 协 议 有 两 种 更 新 机 制 :一 是 定期 更 新 ， 二 是 触发 更 新 。 定 期 更 
新 是 根据 设置 的 更 新 计时 器 定期 发 送 RIP 路 由 通告 。 该 通告 报 文中 携带 
了 除 水 平分 割 机 制 抑制 的 RIP 路 由 之 外 的 本 地 路 由 器 中 所 有 的 RIP 路 由 
言 息 。 而 触发 更 新 则 是 RIP 路 由 器 仅 在 有 路 由 表 项 发 生变 化 时 发 送 的 
RIP 路 由 通告 ， 该 通告 报 文中 仪 携 市 本 地 路 由 表 中 有 变化 的 路 由 信息 。 
RIP 路 由 姨 一 旦 察觉 到 网 络 变 化 ， 就 尽快 甚至 是 立即 发 送 更 新 报 文 ， 而 
` 等 等 更 新 周期 结束 。 只 要 触发 更 新 的 速度 足够 快 ， 就 可 以 最 大 程度 
地 防止 计数 到 无 穷 大 的 情况 发 生 ， 但 是 这 一 现象 还 是 有 可 能 发 生 的 。 


无 论 是 定期 更 新 还 是 触发 更 新 ，RIP 路 由 更 新 都 有 如 下 规则 : 


口 如 果 更 新 的 某 路 由 表 项 在 路 由 表 中 没有 ， 则 直接 在 路 由 表 中 添 
加 该 路 由 表 项 ; 


口 如 末路 由 表 中 己 有 相同 目的 网 络 的 路 由 表 项 ， 且 来 源 端 口 相 
， 那 么 无 条 件 根 据 最 新 的 路 由 信息 更 新 其 路 由 表 ; 


el 


口 如 果 路 由 表 中 已 有 相同 目的 网 络 的 路 由 表 项 ， 但 来 源 端 口 不 
， 则 要 比较 它们 的 度量 值 ， 将 度量 值 较 小 的 一 个 作为 自己 的 路 由 表 
项 ; 


本 


口 如 果 路 由 表 中 已 有 相同 目的 网 络 的 路 由 表 项 ， 且 度量 值 相等 ， 
则 保留 原来 的 路 由 表 项 。 


下 面 主要 介绍 RIP 路 由 的 定期 更 新 机 制 。 


1.RIP 路 由 定期 更 新 机 制 


RIP 路 由 器 总 是 会 每 隔 30s (这 是 默认 值 ， 可 以 修改 ， 而 且 也 可 能 
与 设置 值 有 些 偏差 ) 通过 UDP 520 端 口 以 RIP 广 播 应 答 方式 向 邻居 路 由 
器 发 送 一 个 路 由 更 新 包 ， 包 中 包括 了 本 路 由 器 上 的 完整 的 路 由 表 ( 除 
了 被 水 平分 割 机 制 抑制 的 路 由 表 项 ) ， 用 来 向 邻居 路 由 器 提供 路 由 更 
新 ， 同 时 用 来 向 邻居 路 由 器 证 明 自 己 的 存在 。RIP 的 路 由 表 中 主要 包括 
目的 网 络 、 下 一 跳 地 址 和 距离 这 三 个 字段 ， 如 图 9-4 所 示 。 


如 采 一 个 路 由 器 在 180s 〈 这 也 是 默认 值 ， 可 以 修改 ) 内 没有 收 到 
某 个 邻居 路 由 器 发 来 的 路 由 更 新 ， 则 这 个 路 由 器 束 会 标记 该 邻 大 路 由 
右 为 不 可 达 路 由 右 ， 使 这 个 邻居 路 由 右 处 于 抑制 周期 。 当 路 由 此 处 于 
抑制 周期 内 ， 它 仍然 用 于 癌 前 转发 数据 包 ， 但 网 络 中 的 其 他 路 由 右 不 
学 习 到 达 该 路 由 右 所 连 网 络 的 路 由 信息 ， 除 非 是 一 条 更 好 的 到 达 该 路 
由 妖 所 连 网 络 的 路 由 信息 ， 如 本 来 是 3 跳 ， 在 抑制 周期 内 学 到 了 一 条 2 
跳 的 路 由 信息 。 但 抑制 周期 过 后 ， 即 使 是 差 的 路 由 信息 也 会 被 接受 。 


如 采 在 连续 的 240s (这 也 是 默认 值 ， 可 以 修改 ， 内 还 没收 到 这 个 
路 由 咒 的 路 由 更 新 ， 则 本 地 路 由 器 会 在 路 由 表 中 删除 与 该 邻居 路 由 恬 


相关 的 路 由 表 项 。 


由 此 可 见 ， 这 个 路 由 更 新 不 仅 影响 着 整个 RIP 网 络 中 的 路 由 器 上 路 
由 表 的 更 新 和 所 有 需要 a 到达 或 者 经 过 该 路 由 器 的 数据 包 路 由 ， 还 影响 
着 其 他 邻居 路 由 器 是 否 当 它 存在 。 试 想 一 下 ， 如 果 有 一 个 数据 包 是 
发 送 到 连 毛 某 个 RIP 路 由 器 的 网 络 的 一 台 主 机 上 ， 但 这 台 RIP 路 由 屁 当 
时 恰好 出 现 了 故障 ， 没 有 这 个 路 由 右 更 新 机 制 的 话 ， 其 他 路 由 器 也 就 
不 知道 它 当 前 出 现 了 故障 ， 仍 按 原来 的 路 由 路 径 传输 数据 包 ， 结 果 当 
然 是 数据 包 忆 是 无 法 到 达 目 的 主机 了 ， 尺 管 可 能 经 过 多 次 笑 试 。 


2.RIP 路 由 更 新 机 制 解 析 示 例 
为 了 更 好 地 理解 RIP 协 议 路 由 表 的 更 新 机 制 ， 下 面 以 图 9-5 所 示 的 
简单 的 互连网 络 为 例 来 讨论 路 由 表 是 怎样 建立 的 。 


10.0.0.4 20.0.0:7 20.0.0.9 30.0.0.2 30.0.0.1 


网 络 1 网 络 2 网 络 3 网 络 4 
10.0.0.0 20.0.0.0 30.0.0.0 40.0.0.0 


9-5 ”RIP 路 由 表 建 立 网 络 示例 


1) 在 一 开始 ， 所 有 路 由 器 中 的 路 由 表 只 有 自己 所 直接 连接 的 网 络 
的 路 由 表 项 信息 。 但 不 是 RIP 路 由 表 项 ， 是 直 连 路 由 表 项 ， 无 需 下 一 跳 
(用 “--” 表 示 ) ， 上 度量 “距离 ”也 均 为 0， 各 路 由 絮 的 初始 路 由 表 如 图 9-6 
所 示 ， 均 只 有 两 条 直 连 网 络 的 路 由 表 项 。 


R1 的 路 由 表 R2 的 路 由 表 R3 的 路 由 表 
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图 9-6 R1、R2 和 R3 的 初始 路 由 表 


2) 接 下 来 ， 各 路 由 器 就 会 按 设置 的 周期 (默认 为 30s) 向 邻居 路 
由 器 发 送 路 由 更 新 了 。 具 体 哪个 路 由 器 会 先 发 送 路 由 更 新 ， 取 决 于 路 
由 器 启动 顺序 。 现 假设 路 由 器 R2 先 收 到 来 自 路 由 器 R1 和 R3 的 路 由 更 
新 ， 然 后 其 会 更 新 自己 的 路 由 表 ， 如 图 9-7 所 示 。 从 中 可 以 看 出 ， 它 新 
添加 了 分 别 通过 R1 和 R3 到 达 10.0.0.0 网 络 和 30.0.0.0 网 络 的 路 由 表 项 ， 度 
量 值 均 为 1， 因 为 它 只 经 过 了 一 跳 。 


0 | 0 
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图 9-7 R2 路 由 更 新 后 的 路 由 表 


3) R2 更 新 自己 的 路 由 表 后 ， 会 把 完整 的 路 由 表 发 给 邻居 路 由 器 R1 
和 R3。 路 由 右 R1 和 R3 分 别 再 进行 更 新 。 根 据 前 面 介绍 的 RIP 路 由 表 更 
新 的 规则 可 以 知道 ，R1 首 先是 把 从 R2 上 接收 到 的 路 由 表 的 相应 度量 项 
加 1， 得 到 的 路 由 表 如 图 9-8 所 示 。 


目的 网 络 “| 下 一 吕 
0 | 005 | 1 


30.0.0.0 20.0.0.9 | 时 | 
10.0.0.0 20.0.0.9 
40.0.0.0 20.0.0.9 


图 9-8 ”R1 对 收 到 的 来 自 R2 路 由 表 进 行 度量 加 1 后 形成 的 路 由 表 


4) 然后 R1 再 把 图 9-8 所 示 的 路 由 表 与 自己 原来 的 路 由 表 (图 9-6 中 
的 上 图 所 示 ) 进行 比较 ， 凡 是 新 添加 的 ， 和 度量 值 小 于 等 于 原来 的 路 
由 表 项 均 更 新 ， 度 量 值 更 大 的 路 由 表 项 将 忽略 更 新 。 经 过 比较 发 现 有 
两 条 新 的 路 由 表 项 ， 其 目的 网 络 分 别 为 30.0.0.0 和 40.0.0.0， 直 接 在 路 由 
表 中 添加 。 而 原来 已 有 的 两 条 10.0.0.0 和 20.0.0.0 表 项 ， 发 现 路 由 度量 值 
1 比 原来 的 0 还 大 ， 忽 上 略 更 新 ， 结 果 就 得 到 R1 更 新 后 的 路 由 表 ， 如 图 9-9 
所 示 。 


ml |， 


30.0.0.0 20.0.0.9 | 
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图 9-9 R1 在 收 到 R2 路 由 更 新 后 的 路 由 表 


用 同样 的 方法 ， 可 以 得 出 R3 在 收 到 R2 路 由 更 新 后 的 路 由 表 如 图 9- 
10 所 示 。 


am -| ， 
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图 。9-10”R3 在 收 到 R2 路 由 更 新 后 的 路 由 表 


但 RIP 路 由 协议 存在 一 个 问题 ， 那 融 是 网 络 收 伍 比较 慢 ， 当 网 络 出 
现 故 障 时 ， 要 经 过 比较 长 的 时 间 才 能 将 此 信息 传送 到 所 有 的 路 由 紫 ， 
而 且 中 间 有 许多 是 无 效 路 由 更 新 。 


仍 以 图 9-5 为 例 ， 现 在 三 个 路 由 器 都 已 经 建立 了 各 自 的 稳定 路 由 

表 ， 假 设 R1 路 由 器 和 网 1 (10.0.0.0) 的 连接 线路 断 开 了 。 此 时 R1 可 以 
立即 发 现 ， 并 更 新 自己 的 路 由 表 ， 将 到 10.0.0.0 的 路 由 表 项 距离 改 为 16 
( 即 不 可 达 ) ， 并 在 30s 后 将 此 路 由 更 新 信息 发 给 R2。 但 是 ，R2 从 R3 
得 到 的 路 由 更 新 是 “经 过 R2 到 达 10.0.0.0 网 络 的 距离 为 2”， 明 显 度量 值 更 
小 ， 于 是 R2 将 此 路 由 表 项 更 新 为 “经 过 R3 到 达 10.0.0.0 的 距离 为 9”， 然 
后 再 通过 路 由 更 新 发 给 R3， 此 时 R3 的 路 由 表 中 更 新 为 “经 过 R2 到 达 
10.0.0.0 网 络 的 距离 为 4?。R3 再 通过 路 由 更 新 发 给 R2 人 信息， 结果 是 “经 


过 R3 到 达 10.0.0.0 网 络 的 距离 为 5”， 一 直 如 此 反复 ， 直 到 该 路 由 表 项 的 
距离 达到 16，R2 和 R3 才 知道 10.0.0.0 网 络 是 不 可 达 的 。 


9.1.3 RIP 路 由 收敛 机 制 


任何 距离 向 量 类 路 由 选择 协议 (RIP 也 是 这 类 路 由 协议 ) 都 有 一 
个 问题 ， 路 由 器 不 知道 网 络 的 全 局 情况 ， 路 由 絮 必 须 依靠 相 邻 路 由 表 
来 获取 网 络 的 可 达 信息 。 由 于 路 由 更 新 信息 在 网 络 上 传播 慢 ， 所 以 所 
有 距离 矢量 路 由 算法 都 有 一 个 收敛 慢 的 问题 ， 这 个 问题 将 导致 网 络 中 
各 路 由 器 路 由 信息 不 一 致 的 现象 产生 。RIP 协 议 使 用 以 下 机 制 可 以 减 
少 因 网 络 上 的 不 一 致 性 带 来 的 路 由 选择 环 路 的 可 能 性 。 


1. 记 数 到 无 穷 大 机 制 


RIP 协 议 允 许 最 大 跳 数 值 为 15。 大 于 15 的 目的 地 被 认为 是 不 可 达 
的 。 这 个 数字 在 限制 了 网 络 大 小 的 同时 也 防止 了 一 个 称 为 “ 记 数 到 无 穷 
大 ”的 问题 。 记 数 到 无 穷 大 机 制 的 工作 原理 如 图 9-11 所 示 。 


路 由 器 1 路 由 如 3 


9-11 路 由 需 收 敛 机 制 示 例 


1) 现 假设 路 由 器 1 断 开 了 与 网 络 A 的 连接 ， 此 时 路 由 器 1 会 立即 产 
生 一 个 路 由 更 新 向 其 邻居 路 由 器 2 和 路 由 器 3 通告 ， 告 诉 它 们 ， 路 由 器 1 
不 再 有 到 达 网 络 A 的 路 径 。 假 设 这 个 更 新 信息 传输 到 路 由 万 2 被 推迟 了 
(CPU 忙 、 链 路 拥塞 等 ) ， 但 到 达 了 路 由 器 3， 路 由 器 3 会 立即 从 路 由 
表 中 去 掉 到 网 络 A 的 路 径 。 


2) 但 由 于 路 由 器 2 没有 收 到 路 由 器 1 的 这 个 路 由 更 新 信息 ， 于 是 它 
仍 会 定期 向 它 的 邻居 (包括 路 由 器 1 和 路 由 器 3) 发 送 路 由 更 新 信息 ， 


通告 网 络 A 是 以 2 跳 的 距离 可 达 。 路 由 絮 3 收 到 这 个 更 新 信息 后 ， 认 为 
出 现 了 一 条 通过 路 由 器 2 到 达 网 络 A 的 新 路 径 ， 于 是 路 由 器 3 告诉 路 由 
顷 1， 它 能 以 3 跳 的 距离 到 达 网 络 A。 


3) 路 由 器 1 在 收 到 路 由 絮 3 的 路 由 更 新 后 ， 就 把 这 个 信息 加 上 一 跳 
后 同 路 由 器 2 和 路 由 右 3 同 时 发 出 更 新 信息 ， 告 诉 它 们 路 由 右 1 可 以 以 3 
跳 的 距离 到 达 网 络 A 。 


4) 此 时 路 由 器 2 在 收 到 路 由 器 1 的 消息 后 ， 比 较 发 现 与 原来 到 达 网 
络 A 的 路 径 不 符 ， 更 新 成 可 以 以 4 跳 的 距离 到 达 网 络 A。 这 个 消 恩 再 次 
会 发 往 路 由 器 3， 以 此 循环 ， 直 到 跌 数 达到 超过 RIP 协 议 允 许 的 最 大 值 
(在 RIP 中 定义 为 15) 。 一 旦 一 个 路 由 器 达到 这 个 值 ， 它 将 声明 这 条 
路 径 不 可 用 ， 并 从 路 由 表 中 删除 此 路 径 。 


由 于 记 数 到 无 穷 大 问题 ， 路 由 选择 信息 将 从 一 个 路 由 器 传 到 为 一 
个 路 由 右 ， 每 次 跳 数 加 1。 路 由 远 择 环 路 问题 将 无 限制 地 进行 下 去 ， 除 
非 达 到 某 个 限制 。 这 个 限制 就 是 RIP 的 最 大 跳 数 。 当 路 径 的 跳 数 超过 
15， 这 条 路 径 才 从 路 由 表 中 删除 。 


2. 水 平分 割 法 


水 平分 割 就 古 使 路 由 器 不 同 对 应 路 由 更 新 表 项 输入 的 方向 回 传 此 
条 路 由 表 信息 ， 使 它 只 沿 一 个 方 加 通告。 通俗 地 讲 回 是 ， 如 果 一 条 路 


由 信息 是 从 某 个 端口 学 习 到 的 ， 那 么 从 该 端口 发 出 的 路 由 更 新 中 将 不 
再 包含 该 条 路 由 信息 ， 其 目的 就 是 为 了 避免 出 现 路 由 更 新 环 路 。 


在 图 9-12 所 示 的 网 络 中 ， 路 由 器 2 通过 巾 中 继 连 接 路 由 器 1 和 路 由 
器 3， 两 个 PVC (永久 虚 电 路 ) 都 在 路 由 器 2 的 同一 个 物理 接口 (S50) 
中 止 。 如 果 在 路 由 器 2 局 用 了 水 平分 割 功能 ， 那 么 路 由 器 3 将 收 不 到 路 
由 器 1 的 路 由 选择 信息 ， 反 之 亦 然 。 因 为 路 由 侨 1， 或 路 由 器 3 癌 路 由 器 
2 通告 的 路 由 更 新 信息 不 会 再 从 S0 接 口 向 外 通告 给 路 由 器 3 或 路 由 器 


1 。 


路 由 如 3 


路 由 器 1“、、、 


S0 接口 
路 由 如 2 


图 9-12 水平 分割 示例 


在 如 图 9-5 所 示 的 网 络 中 ， 如 果 R2 启 用 了 水 平分 割 功能 ， 则 R2 在 
收 到 R1 改 来 的 包括 10.0.0.0 网 络 的 路 由 更 新 后 ， 在 网 R1 发 送 的 路 由 更 
新 中 束 不 会 再 包括 10.0.0.0 对 应 的 路 由 表 项 了 ， 这 样 束 可 以 避免 路 由 表 
发 送 的 死 循环 出 现 。 


3. 毒 性 逆转 水 平分 割 法 


水 平分 割 功能 是 路 由 絮 用 来 防止 把 一 个 接口 得 来 的 路 径 又 从 此 接 
口传 回 ， 导 致 路 由 更 新 环 路 的 出 现 。 毒 性 逆转 水 平分 割 方法 是 在 更 新 
信息 中 包括 这 些 回 传 路 径 ， 但 会 把 这 些 回 传 路 径 的 跳 数 设 为 16 (无 
穷 ) 。 通 俗 地 讲 就 是 ， 如 果 一 条 路 由 信息 是 从 某 个 端口 学 习 到 的 ， 那 
么 从 该 端口 发 出 的 路 由 更 痢 分 组 中 将 继续 包含 该 条 路 由 信息 ， 但 将 这 
条 信息 的 metric 置 为 16。 通 过 把 跳 数 设 为 无 穷 ， 并 把 这 条 路 径 告诉 源 
路 由 器 ， 能 够 更 快 地 消除 路 由 信息 的 环 路 。 但 它 增 加 了 路 由 更 新 的 负 
担 。 


4. 保 持 定时 器 法 


保持 定时 器 法 是 设置 路 由 信息 被 抑制 的 时 间 ， 上 默认 为 180s。 当 路 
由 屁 接 收 到 一 个 不 可 达 的 路 由 更 新 时 ， 路 由 右 将 会 把 这 条 路 由 更 新 置 
于 无 效 抑制 状态 ， 不 再 接收 对 应 路 由 的 更 狐 信 息 ， 也 不 同 外 发 送 这 条 


路 由 更 新 信息 ， 一 直 持 续 到 接收 到 一 个 市 有 更 好 度量 的 对 应 路 由 更 狐 
分 组 或 者 相应 保持 计时 器 到 期 为 止 。 


在 图 9-12 所 示 的 网 络 中 ， 由 于 线路 原因 ， 从 路 由 如 1 发 往 路 由 絮 2 
的 路 由 更 新 补 延 迟到 达 ， 人 致使 路 由 器 2 不 能 及 时 更 新 ， 所 以 路 由 右 2 仍 
会 将 新 的 错误 路 由 信息 发 送 给 路 由 器 3。 但 使 用 了 保持 计数 万 法 后 ， 这 
种 情况 将 不 会 发 生 ， 因 为 路 由 器 3 在 收 到 来 目 路 由 絮 1 的 网 络 A 不 可 达 
的 路 由 更 新 后 ， 将 在 180s 内 不 接受 通 同 网 络 A 的 新 的 路 由 信息 ， 而 经 
过 这 段 时 间 后 ， 路 由 器 2 也 已 正确 进行 了 更 新 ， 将 不 会 再 发 送 错 误 的 路 
由 信息 给 路 由 右 3。 


9.1.4 ”RIP 报 文 格式 


前 面 说 了 ，RIP 使 用 UDP 报 文 在 邻居 路 由 器 间 交 换 路 由 表 ， 所 使 用 
的 UDP 端口 号 为 520。 通 常情 况 下 RIPv1 报 文 为 广播 报 文 ， 而 RIPv2 报 文 
为 组 播报 文 ， 组 播 地 址 为 224.0.0.9， 默 认 每 隔 30s 向 邻居 路 由 器 发 送 一 
次 路 由 更 新 报 文 。 如 果 设 备 经 过 180s 没 有 收 到 来 自 对 端的 路 由 更 新 报 
文 则 将 所 有 来 自 此 设备 的 路 由 信息 标志 为 不 可 达 ， 若 在 240s 内 仍 未 收 
到 更 新 报 文 就 将 这 些 路 由 从 路 由 表 中 删除 。 如 图 9-13 所 示 为 RIP 路 由 更 
新 报 文 格式 ， 注 意 其 中 v1 版 本 和 v2 版 本 的 不 同 。 


疏 


去 ] >|< 1 ”< 2 ”| 
报头 部 分 十 | Command 
Address Family Identifier | Route Tag ( 仅 v2 版 本 ，v1 版 本 值 为 0 ) 
IP Address 
Subnet Mask ( 仅 v2 版 本 ，vl 版 本 值 为 0 ) 
Next Hop( 仅 v2 版 本 ，v1 版 本 值 为 0 ) 


Metric 


二 


Version | Unused 


路 由 表 
项 部 分 


图 。9-13 ”RIP 协议 报 文 格式 
(1) Command 


命令 字段 ， 占 1 字 节 ， 用 来 指定 数据 报 分 组 是 请 求 分 组 还 是 响应 分 
组 。 在 v1 版 本 中 主要 有 以 下 四 种 分 组 类 型 Request (请 求 ， 对 应 值 为 
1) 、Response 〈 响 应， 对 应 值 为 2) 、Traceon (启用 跟踪 标记 ， 对 应 


值 为 3， 自 v2 版 本 后 已 经 淘汰 ) 、Traceoff (关闭 跟踪 标记 ， 对 应 值 为 
4， 目 v2 版 本 后 已 经 淘汰 ) 。 请 求 分 组 是 请 求 邻居 路 由 器 发 送 全 部 或 部 
分 路 由 表 信 息 的 分 组 ， 啊 应 分 组 可 以 是 路 由 右 主 动 提 供 的 周期 性 路 由 
更 新 分 组 或 者 对 请 求 分 组 的 响应 。 


(2) Version 

版 本 字段 ， 占 1 字 节 ，v1 版 本 值 为 1，v2 版 本 值 为 2。 
(3) Unused 

未 使 用 的 字段 ， 占 2 字 节 ， 值 固定 为 0。 

(4) Address Family Identifier (AEFI) 


地 址 族 标 识 符 字段 ， 占 2 字 广 ， 指 出 所 使 用 的 地 址 族 。RIP 设 计 用 
于 携带 多 种 不 同 协议 的 路 由 信息 ， 每 个 项 都 有 地 址 族 标志 来 表明 使 用 
的 地 址 类 型 ，IP 地 址 的 AFI 是 2。 


(5) Route Tag 


路 由 标记 字段 ， 占 2 字 节 ， 提 供 区 分 内 部 路 由 (由 RIP 学 得 ) 和 外 
部 路 由 (由 其 他 协议 学 得 ) 的 方法 。 它 携带 着 一 个 EGP 和 BGP 的 自治 系 
统 号 。 该 字段 仅 在 v2 版 本 使 用 ， 使 用 对 应 外 部 路 由 的 标记 值 ，v1 版 本 


不 用 〈 值 固定 为 0) ， 因 为 v1 版 本 不 文 持 由 其 他 类 型 路 由 重新 发 布 为 
RIP 路 由 。 


(6) IP Address 


IP 地 址 字段 ， 占 4 子 广 ， 指 定 路 由 的 目的 网 络 地 址 ， 可 以 古 标准 网 
段 地 址 、 子 网 地 址 。 


(7) Subnet Mask 


子 网 掩 码 字 段 ， 占 4 子 方 ， 指 定 目 的 网 络 的 子 网 掩 码 ， 仪 在 v2 版 本 
中 使 用 ，v1 版 本 中 该 子 段 值 固定 为 0° 因为 v1 版 本 不 支持 无 类 别 网 络 ， 
也 束 是 不 文 持 于 网 ， 仪 支持 标准 的 有 类 网 络 ， 此 时 具体 网 段 的 于 网 掩 
码 是 固定 的 。 


(8) Next Hop 


下 一 跳 字 段 ， 占 4 字 节 ， 指 出 RIP 路 由 的 下 一 跳 的 IP 地 址 。 如 果 为 
0.0.0.0， 则 表示 发 布 此 条 路 由 信息 的 路 由 器 地 址 束 是 最 优 下 一 跳 地 址 。 
该 字段 也 仅 在 v2 版 本 中 使 用 ，v1 版 本 中 该 字段 值 固定 为 0， 因 为 v1 版 本 
采用 的 是 广播 方式 发 送 ， 无 具体 的 下 一 跳 。 


(9) Metric 


RIP 路 由 的 Metric (度量 ) 值 字 段 ， 也 就 是 “距离 ” 值 ， 占 4 字 世 ， 最 
大 有 效 值 为 15，16 时 表示 该 路 由 不 可 达 了 。 


说 明 在 以 上 整个 RIP 报 文 各 字段 中 可 分 为 头 部 (Header) 和 路 由 
表 项 (Route Entries) 两 大 部 分 。 头 部 包括 Command、Version 和 Unused 
这 三 个 字段 ， 其 余 字 段 都 属于 路 由 表 项 。 在 一 个 RIP 报 文中 ， 最 多 可 以 
有 25 个 路 由 表 项 ， 也 就 是 在 一 个 RIP 分 组 中 最 多 可 含有 25 个 地 址 项 ， 即 
一 个 分 组 中 最 多 可 一 次 性 通告 25 条 RIP 路 由 表 项 。 


9.2 OSPF 路 由 协议 


由 于 RIP 协 议 主要 用 于 小 型 网 络 ， 在 20 世 纪 80 年 代 中 期 束 已 不 能 
适应 大 规模 异 构 网 络 的 互 连 ， 一 种 互 连 功能 更 强大 的 路 由 协议 一 一 
OSPF (Open Shortest Path First， 开 放 式 最 短路 径 优先 协议 ) 就 随 之 产 
生 了 。 它 是 Intermet 工 程 任务 组 织 (IETF) 的 内 部 网 关 协 议 工作 组 为 IP 
网 络 而 开发 的 一 种 路 由 协议 ， 作 为 RIP 的 后 继 内 部 网 关 协 议 ， 目 前 它 
的 最 新 版 本 是 第 4 版 ， 即 OSPFv4。 


9.2.1 ”OSPF 协议 简介 


OSPF 也 是 一 个 内 部 网 关 协 议 ， 用 于 单个 自治 体系 (AS) 的 路 由 
絮 之 间 。OSPF 采 用 链 路 状态 技术 ， 路 由 器 互 相 发 送 直 接 相 连 的 链 路 信 
恩 和 它 所 拥有 的 到 其 他 路 由 右 的 链 路 信息 。 每 个 OSPF 路 由 兹 维护 相同 
AS 折 扑 结构 的 数据 库 。 从 这 个 数据 库 里 ， 构 造 出 最 短路 径 树 来 计算 出 
路 由 表 。 当 拓扑 结构 发 生变 化 时 ，OSPF 协 议 能 迅速 重新 计算 出 路 径 ， 
而 只 产生 少量 的 路 由 协议 流量 。 此 外 ， 所 有 的 OSPF 路 由 选择 分 组 的 交 
换 都 是 经 过 验证 的 。 


OSPF 协 议 与 RIP 协 议 相 比 要 复杂 许多 ， 主 要 表现 在 以 下 几 个 方 
面 : 


(1) 采用 链 路 状态 路 由 算法 


RIP 采 用 相对 人 和 单 的 “距离 天 量 ” 路 由 算法 ， 仅 以 “距离 ”作为 度量 
而 OSPF 采 用 的 是 更 加 复杂 的 “ 链 路 状态 ”路 由 算法 ， 考 虑 的 因素 非常 
多 ， 包 括 线路 市 宽 、 端 口 状态 、 端 口 开 销 、 端 口 优 移 级 、 链 路 稳定 性 
等 。 


(2) 可 划分 不 同 区 域 


虽然 在 一 个 OSPF 网 络 中 ， 只 能 有 一 个 AS， 但 在 这 个 AS 中 可 以 划 
分 多 个 区 域 (Area) ， 同 一 个 区 域 的 不 同 OSPF 路 由 器 进程 可 以 一 样 ， 
也 可 以 不 一 样 。 在 OSPF 路 由 协议 中 ， 每 一 个 区 域 中 的 路 由 硕 都 按照 该 
区 域 中 定义 的 链 路 状态 算法 来 计算 网 络 拓扑 结构 ， 这 意味 着 每 一 个 区 
域 都 有 着 该 区 域 独 立 的 网 络 拓 扑 数 据 库 及 网 络 拓 扑 图 。 对 于 每 一 个 区 
域 ， 其 网 络 拓 扑 结 构 在 区 域外 是 不 可 见 的 ， 同 样 ， 在 每 一 个 区 域 中 的 
路 由 器 对 其 域外 的 其 余 网 络 结构 也 不 了 解 。 这 样 做 有 利于 减少 网 络 中 
链 路 状态 数据 包 在 全 网 范围 内 的 广播 ， 也 是 OSPF 将 其 路 由 域 或 一 个 
AS 划分 成 很 多 个 区 域 的 重要 原因 。 


(3) 有 不 同 路 由 器 角色 


正 因 为 OSPF 可 以 划分 为 多 个 不 同 的 区 域 ， 所 以 就 涉及 相同 区 域内 
部 ， 以 及 不 同 区 域 间 的 路 由 问题 。 这 也 整 决 是 了 在 OSPF 网 络 中 存在 多 


种 不 同类 型 的 路 由 各 ， 并 担当 不 同 角 色 ， 如 区 域内 部 路 由 做 、 区 域 边 
界 路 由 侨 、AS 边 界 路 由 器 等 。 具 体 将 在 本 章 后 面 专门 介绍 。 


(4) 收敛 性 能 更 高 


在 RIP 协 议 中 ， 所 有 的 路 由 都 由 跳 数 来 描述 ， 到 达 目 的 地 的 路 由 
最 大 不 超过 15 跳 ， 这 就 限制 了 RIP 的 服务 半径 ， 即 其 只 适用 于 小 型 的 
简单 网 络 。 同 时 ， 运 行 RIP 协 议 的 路 由 器 需要 定期 (默认 为 30s) 在 网 
络 邻 居 路 由 人 右上 通告 目 己 的 整个 路 由 表 人 信息， 以便 及 时 对 网 络 拓扑 结 
构 的 改变 进行 收 公 。 这 样 的 收敛 方式 ， 不 仅 速 度 慢 ， 而 且 极 容易 引起 
通告 风暴 〈 尤 其 是 在 路 由 更 新 包 发 送 频率 加 大 时 ) 或 者 造成 路 由 环 路 


A NA 
等 问题 。 


OSPF 是 基于 链 路 状态 的 路 由 协议 ， 它 克服 了 RIP 路 由 收敛 慢 的 缺 
陷 。 因 为 OSPF 路 由 需 不 再 交换 整个 路 由 表 ， 而 是 同步 各 路 由 器 对 网 络 
状态 的 认识 ， 即 链 路 状态 数据 库 ， 然 后 通过 Dijkstra 最 短路 径 算 法 计算 
出 网 络 中 各 目的 地 址 的 最 优 路 由 。 这 样 OSPF 路 由 器 间 不 需要 定期 交换 
大 量 数据 ， 而 只 保持 着 一 种 连接 ， 仅 在 链 路 状态 发 生变 化 时 ， 才 通过 
组 播 方式 对 这 一 变化 做 出 反应 。 这 样 不 但 减轻 了 系统 的 负 人 入， 而 且 达 
到 了 对 网 络 拓扑 的 快速 收敛 ， 因 此 OSPF 路 由 协议 即使 是 在 大 型 网 络 中 
也 能 够 较 快 地 收敛 。 而 这 些 正 是 OSPF 强 大 生命 力 和 应 用 洪 力 的 根本 所 
在 。 


总 体 来 说 ，OSPF 具 有 如 下 特点 : 


口 适应 范围 广 一 一 文 持 各 种 规模 的 网 络 ， 最 多 可 文 持 几 百 人 台 路 由 


口 快速 收 鲍 在 网 络 的 拓扑 结构 发 生变 化 后 立即 发 送 更 新 报 
文 ， 使 这 一 变化 在 自治 系统 中 同步 。 


口 无 目 环 一 一 由 于 OSPF 根 据 收集 到 的 链 路 状态 用 最 短路 径 树 算法 
计算 路 由 ， 从 算法 本 喘 保证 了 不 会 生成 目 环 路 由 。 


口 文 持 区 域 划分 一 一 允许 目 治 系统 的 网 络 被 划分 成 区 域 来 管理 ， 
区 域 间 传 送 的 路 由 信息 被 进一步 抽象 ， 从 而 减少 了 占用 的 网 络 市 宽 。 


口 文 持 等 价 路 由 一 一 文 持 到 同一 目的 地 址 的 多 条 等 价 路 由 。 


口 文 持 路 由 分 级 划分 一 一 使 用 4 类 不 同 的 路 由 ， 按 优 和 顺序 来 说 依 
次 征 区 域内 路 由 、 区 域 间 路 由 、 第 一 类 外 部 路 由 、 第 二 类 外 部 路 由 。 


口 文 持 验 证 一 一 文 持 基 于 接口 的 报 文 验 证 ， 以 保证 报 文 交互 和 路 
由 计算 的 安全 性 。 


口 文 持 组 播发 送 一 一 在 某 些 类 型 的 链 路 上 可 以 以 组 播 地 址 形式 发 
送 协议 报 文 ， 减 少 对 其 他 设备 的 干扰 。 


9.2.2 ”OSPF 的 AS 与 Area 


学 习 OPSF 路 由 ， 首 先 要 从 AS (自治 系统 ) 和 Area (区 域 ; 这 两 
个 概念 学 起 ， 否 则 你 根本 无 法 理解 本 章 后 面 将 要 介绍 的 各 种 OSPF 技 术 
和 路 由 工作 原理 。 


1. 理 解 AS 


AS 是 一 组 使 用 相同 路 由 协议 交换 路 由 信息 的 路 由 釉 ， 又 称 路 由 域 
(Routing Domain) 。 它 可 以 是 一 个 路 由 器 直接 连接 到 一 个 LAN 上 ， 
然后 连 到 Internet 上 ; 也 可 以 是 一 个 由 企业 骨干 网 互 连 的 多 个 局 域 网 。 
同一 个 As 中 的 所 有 路 由 器 必须 相互 连接 ， 运 行 相同 的 路 由 协议 ， 同 时 

分 配 同一 个 AS 号 。 


在 OSPF 网 络 中 ， 只 有 在 同一 AS 中 的 路 由 器 才 会 相互 交换 链 路 状 
态 信息 ; 在 同一 个 AS 中 ， 所 有 的 OSPF 路 由 器 都 维护 一 个 相同 AS 结构 
描述 的 数据 库 。 该 数据 库 中 存放 的 是 路 由 域 中 相应 链 路 的 状态 信息 。 
OSPF 路 由 器 正 是 通过 这 个 数据 库 计 算出 其 OSPF 路 由 表 的 。 而 且 OSPF 
可 以 将 一 个 AS 分 割 成 多 个 小 的 区 域 ， 便 于 网 络 的 拓展 ， 而 且 每 个 
OSPF 路 由 器 只 在 区 域内 部 学 习 完整 的 链 路 状态 信息 ， 便 于 路 由 更 新 管 
理 。 


默认 情况 下 ， 在 OSPF AS 中 的 每 个 OSPF 路 由 器 必须 在 其 LSDB 
( 链 路 状态 数据 库 ) 中 保持 有 其 他 每 个 路 由 器 的 LSA ( 链 路 状态 通 
告 ) 。 这 样 一 来 ， 在 较 大 型 的 OSPF 网 络 中 ， 每 个 路 由 器 中 所 保持 的 
LSDB 都 比较 大 ， 进 行 SPF (最 短路 径 优 先 ) 运算 时 需要 消耗 大 量 的 系 
统 资源 。 同 时 ， 所 导致 的 直接 结果 就 是 路 由 表 可 能 非常 大 ， 包 含 了 到 
达 AS 中 其 他 所 有 网 络 的 路 由 。 


2. 理 解 Area 


为 了 减 小 LSDB 的 大 小 ， 降 低 SPF 运 算 的 系统 资源 开销 ， 减 少 路 由 
表 项 数 ，OSPF 人 允许 AS 被 划分 成 多 个 连续 网 络 群 组 ， 这 就 是 “区 
域 ”(Area) 。 一 个 Area 就 是 指 OSPF 路 由 域 ， 或 者 AS 的 一 部 分 ， 也 就 
是 说 在 一 个 AS 中 可 以 划分 成 多 个 区 域 。 通 过 使 用 区 域 ， 可 将 大 型 网 络 
划分 成 适合 运行 SPF 〈 最 短路 径 优先 ) 路 由 算法 的 小 块 。 图 9-14 所 示 的 
就 是 一 个 包含 4 个 区 域 的 OSPF 网 络 ， 从 中 可 以 看 出 ， 各 区 域 也 是 通过 
路 由 器 进行 相互 连接 的 ， 此 时 这 些 路 由 器 就 是 区 域 边界 路 由 妖 ， 它 们 
至 少 位 于 两 个 区 域 中 。 当 然 ， 在 每 个 区 域内 部 还 会 有 路 由 器 ， 这 些 就 
是 前 面 所 说 的 区 域内 部 路 由 器 。 
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9-14 ”包含 多 个 区 域 的 OSPF 网 络 示例 


在 OSPF 路 由 协议 中 ， 每 一 个 区 域 中 的 路 由 需 都 独立 于 计算 网 络 折 
扑 结构 ， 区 域 间 的 网 络 结构 情况 是 互 不 可 见 的 。 每 一 个 区 域 中 的 路 由 
堪 也 不 会 了 解 外 部 区 域 的 网 络 结构 ， 可 谓 是 “各 目 为 政 ， 互 不 干涉 ”。 
这 束 意 味 着 每 一 个 区 域 都 有 看 该 区 域 独立 的 网 络 拓 扑 数 据 库 及 网 络 拓 
扑 图 。 这 样 做 的 好 处 就是 有 利于 减少 网 络 中 LSA 报 文 在 整个 OSPF 网 络 
范围 内 的 通告 。 


不 同 区 域 是 通过 一 个 四 段 、 最 多 12 位 的 十 进 制 点 分 形式 《与 卫 地 
址 的 表示 形式 一 样 ) 的 区 域 ID 来 进行 标识 的 ， 如 1.1.1.1。 但 是 ， 一 个 


ID 仅 是 一 个 管理 标识 符 ， 与 IP 地 址 或 者 IP 网 络 ID 没 有 任何 关系 。 但 是 
如 果 在 一 个 AS 中 的 一 个 区 域 中 的 各 网 段 IP 地 址 都 是 在 一 个 网 络 或 子 网 
中 ， 则 出 于 管理 上 的 便利 ， 可 以 将 区 域 ID 设置 为 对 应 的 网 络 或 子 网 
ID。 例 如 ， 如 果 一 个 区 域 中 所 在 网 段 都 是 在 10.1.0.0 这 个 网 络 之 中 ， 则 
区 域 ID 可 以 设置 为 10.1.0.0。 


为 了 使 每 个 路 由 器 的 LSDB 最 小 ， 一 个 区 域 中 的 网 络 LSA 报 文 只 后 
区 域内 部 的 路 由 器 泛 洪 ， 而 不 会 向 区 域外 的 路 由 器 泛 洪 。 每 个 区 域 以 
自己 的 LSDB 构 成 自己 的 链 路 状态 域 。 如 果 一 个 路 由 器 连接 了 多 个 区 
域 ， 则 它 有 多 个 LSDB 和 SPF 树 。 它 的 路 由 表 就 是 该 路 由 器 所 有 SPF 树 
中 的 路 由 表 项 的 组 合 。 为 了 减少 OSPF 路 由 器 路 由 表 中 的 路 由 条 目 数 
量 ， 在 区 域内 部 的 网 络 可 以 使 用 汇总 路 由 通告 (Summary-LSA) 向 区 
域外 通告 ， 也 就 是 一 个 多 个 子 网 的 LSA 以 一 个 大 的 网 络 LSA 形 式 进 行 


通告 。 


9.2.3 OSPF 网 络 路 由 器 类 型 


前 面 说 了 ， 在 OSPF 网 络 中 ， 不 仅 有 AS 之 分 ， 在 同一 个 AS 内 部 又 
可 以 划分 多 个 不 同 的 区 域 。 当 一 个 AS 划分 成 几 个 OSPF 区 域 时 ， 根 据 该 
路 由 右 在 相应 的 区 域 之 内 或 者 区 域 之 间 ， 甚 至 不 同 OSPF AS 之 间作 用 
的 不 同 ， 可 以 将 OSPF 路 由 器 做 如 下 分 类 : 


(1) 内 部 路 由 器 (Internal Router，IR) 


当 一 个 OSPF 路 由 右上 所 有 直 连 的 链 路 (也 束 是 路 由 器 上 所 有 接 
口 ) 都 处 于 同一 个 区 域 (不 直接 与 其 他 区 域 相连 ) 时 ， 我 们 称 这 种 路 
由 天 为 内 部 路 由 融 。 内 部 路 由 邵 上 仅仅 运行 其 所 属 区 域 的 OSPF 运 算法 
则 ， 仅 生成 区 域内 部 的 路 由 和 项 。 


(2) 区 域 边 界 路 由 器 (Area Border Router，ABR) 


当 一 个 路 由 右 有 多 个 接口 ， 其 中 至 少 有 一 个 接口 与 其 他 区 域 相连 
时 ， 我 们 称 之 为 “区 域 边界 路 由 右 ”。 区 域 边界 路 由 屁 的 各 对 应 接口 运 
行 与 其 相连 区 域 定义 的 OSPF 运 算法 则 ， 具 有 相连 的 每 一 个 区 域 的 网 络 
结构 数据 ， 并 且 了 解 如 何 将 该 区 域 的 链 路 状态 信息 通告 至 骨干 区 域 ， 
再 由 骨干 区 域 转发 至 其 余 区 域 。 有 关 OSPF 的 区 域 分 类 将 在 本 市 后 面 各 


A I 


(3) AS 边界 路 由 器 (Autonomous System Boundary Router， 


ASBRI) 


AS 边界 路 由 需 是 与 AS 外 部 的 路 由 器 互相 交换 路 由 信息 的 OSPF 路 
由 器 。 该 路 由 器 在 AS 内 部 通告 其 所 得 到 的 AS 外 部 路 由 人 信息， 这样 AS 内 
部 的 所 有 路 由 器 都 知道 AS 边 界 路 由 器 的 路 由 信息 。AS 边 界 路 由 姨 的 定 
义 与 前 面 几 种 路 由 器 的 定义 是 相互 独立 的 ， 一 个 AS 边 界 路 由 器 可 以 是 
一 个 区 域内 部 路 由 器 ， 或 是 一 个 区 域 边界 路 由 器 。 


(4) 骨干 路 由 器 (Backbone Router) 


骨干 路 由 器 是 指 至 少 有 一 个 接口 定义 为 属于 骨干 区 域 的 路 由 器 。 
任何 一 个 与 骨干 区 域 互 连 的 ABR 或 者 ASBR 也 将 成 为 骨干 路 由 器 。 有 关 
OSPF 骨 干 区 域 也 将 在 后 面 介绍 。 


以 上 四 类 OSPF 网 络 路 由 右 所 处 的 位 置 如 图 9-15 所 示 。 从 中 可 以 看 
出 它们 之 间 的 关系 。 


Area 1 Area 0 Area 2 


ABR/ 骨干 
路 由 器 


骨干 区 域 
内 部 路 由 器 


内 部 路 由 器 


ASBR/ 骨干 External ASBR/ 骨干 
路 由 器 AS 路 由 如 


图 。 9-15 OSPF 网 络 的 主要 路 由 器 类 型 示例 


9.2.4 DR 和 BDR 


在 一 个 广播 性 、 多 路 访问 的 网 络 (例如 Ethermet、TokenRing 及 

FDDI 环 境 ) 中 ， 如 果 每 个 路 由 器 都 独立 地 与 其 他 路 由 器 进行 LSU 

(Link State Update Packet， 链 路 状态 更 新 包 ) 交换 ， 以 同步 各 自 的 
LSDB， 将 导致 一 个 巨大 的 流量 增长 。 为 了 防止 出 现 这 种 现象 ， 同 时 使 
路 由 器 保存 的 链 路 状态 信息 最 少 ，OSPF 在 这 类 网 络 上 选举 出 一 个 DR 

(Designated Router， 指 定 路 由 器 ) 和 BDR (Backup Designated 
Router， 备 份 指定 路 由 器 ) 。 区 域内 那些 既 不 是 DR， 也 不 是 BDR 的 路 
由 器 称 为 DR Other。 


1.DR 和 BDR 的 主要 作用 


DR 就 是 集中 负责 一 个 区 域内 各 路 由 器 间 的 LSU 交 换 和 邻接 关系 建 
立 ， 相 当 于 这 个 区 域 的 负责 人 一 样 。 由 于 OSPF 路 由 器 之 间 是 通过 建立 
六 接 关 系 及 以 后 的 泛 洪 来 同步 链 路 状态 数据 库 的 ， 所 以 DR 必须 与 所 有 
同一 区 域 的 OSPF 路 由 器 建立 邻接 关系 (其 他 路 由 右 间 不 必 建 立 邻 接头 
系 ) ， 负 责 集 中 管理 、 维 护 和 组 播 下 发 区 域内 各 路 由 器 发 来 的 链 路 状 
态 信息 。DR 或 者 BDR 通 党 是 处 于 一 个 区 域 的 中 心地 位 ， 使 其 他 路 由 器 
与 它 建立 邻接 关系 的 难 易 程度 相当 。BDR 用 于 在 DR 失效 后 接替 DR 的 工 
作 (也 可 不 选举 BDR) ， 在 DR 正常 工作 时 ， 它 不 承担 DR 的 职责 。 在 同 
一 个 OSPF 区 域 中 ， 每 个 路 由 帮 都 和 DR、BDR 相 连 。 


A> 


下 像 一 个 团体 ， 其 中 必须 要 指定 一 个 负责 人 。 这 个 负责 人 人 负责 其 
他 成 员 的 信息 反馈 、 转 发 和 广播 (保存 有 所 有 成 员 之 间 的 联系 信 
息 ) ， 其 他 每 个 成 员 也 都 与 这 个 负责 人 建立 单线 联系 ， 而 其 他 成 员 之 
间 彼此 不 建立 联系 。 这 样 束 不 需要 每 个 成 员 都 保存 整个 团体 会 员 的 联 
系 信 息 ， 也 不 必 每 个 成 员 都 与 其 他 成 员 建 立 联系 ， 管 理 更 加 人 简单。 这 
个 团体 的 负责 人 融 相 当 于 这 里 所 说 的 DR 了 。 


当 区 域 中 的 路 由 器 有 路 由 更 新 时 ，DR Other 路 由 器 不 会 向 其 他 DR 
Other 路 由 器 发 送 自己 的 LSU， 只 会 向 224.0.0.6 这 个 组 播 地 址 发 送 ， 然 
后 由 224.0.0.6 这 个 地 址 把 DR Other 发 来 的 LSU 组 播 给 DRMBDR。 在 
DR/BDR 收 到 从 224.0.0.6 发 过 来 的 LSU 后 又 会 把 这 些 LSU 发 给 224.0.0.5 
这 个 组 播 地 址 ，224.0.0.5 再 把 LSU 泛 洪 到 区 域内 的 所 有 DR Other 路 由 器 
上 。 这 样 ， 区 域 网 络 上 的 所 有 DR Other 路 由 器 都 会 知道 这 个 起 源 的 DR 
Other 路 由 器 发 送 的 路 由 更 新 ， 而 不 用 向 每 个 DR Other 路 由 器 都 发 送 一 
次 路 由 更 新 。 


在 图 9-16 所 示 的 示例 中 ， 假 设 一 开始 没有 选举 DR 和 BDR， 则 在 其 
中 的 任何 一 台 路 由 器 的 路 由 发 生 了 改变 时 ， 区 域内 的 其 他 路 由 器 都 得 
重新 进行 SPF 计 算 ， 生 成 新 的 LSDB 表 项 。 但 如 果 选 举 了 R3 作 为 DR， 
R4 和 R5 均 为 DR Other， 则 当 R4 所 连接 的 网 络 发 生变 化 时 ，R4 只 会 把 目 
己 的 LSU 发 送 到 224.0.0.6 这 个 组 播 地 址 ， 然 后 224.0.0.6 会 把 这 个 LSU 传 
送 给 R3。R3 在 收 到 R4 的 LSU 后 会 对 比 目 己 的 LSDB， 发 现 LSDB 里 面 只 


有 关于 R4 的 条 目 需要 更 新 ， 于 是 便 把 一 个 关于 R4 的 LSU 发 送 到 
224.0.0.5 组 播 地 址 ， 这 时 224.0.0.5 就 会 在 整个 区 域 中 组 播 R4 的 这 一 个 
LSU 包 。R5 收 到 224.0.0.5 发 过 来 LSU 之 后 直接 更 新 自己 LSDB， 不 需要 
重新 进行 SPF 计 算 。 


DR Other py 再 


Be 了 DR Other < 


图 9-16 DR 应 用 示例 


通过 这 样 一 种 LSU 发 送 方式 ， 就 变 原来 的 “多 点 对 多 点 ”信息 发 送 方 
式 为 < 单 点 到 多 点 ”信息 发 送 方式 。 这 样 有 两 个 好 处 ， 一 是 可 更 有 效 地 
利用 网 络 带宽 资源 ， 二 是 可 提高 LSU 信 息 发 送 效率 。 


DR Other 仅 与 DR 和 BDR 之 间 建 立 邻 接 关 系 ，DR Other 之 间 不 交换 
任何 路 由 信息 。 这 样 就 减少 了 广播 网 和 NBMA 网 络 上 各 路 由 器 之 间 邻 
接 关 系 的 数量 ， 同 时 减少 了 网 络 流量 ， 市 约 了 带宽 资源 。 如 图 9-17 所 
示 ， 用 实 线 代表 以 太 网 物理 连接 ， 虚 线 代表 建立 的 邻接 关系 。 可 以 看 
到 ， 采 用 DR/BDR 机 制 后 ，5 台 路 由 器 之 间 只 需要 建立 7 个 邻接 关系 就 可 
以 了 ， 如 果 不 选 举 DR 和 BDR 的 话 ， 大 家 画 一 下 ， 看 有 多 少 条 邻接 天 
系 o 


DRother DRother DRother 


图 9-17 DR 和 BDR 示 意图 
2.DR 和 BDR 的 选举 


DR 和 BDR 也 不 古 随便 担当 的 ， 需 要 选举 产生 ， 就 像 我 们 在 学 校 选 
正 、 副 班长 一 样 ， 也 是 要 投票 选举 的 。DR 是 通过 接口 优先 级 


(Interface Priority) 进行 选举 ， 最 高 优先 级 的 路 由 器 被 选 为 DR， 次 高 
者 被 选 为 BDR; 如 果 接 口 优先 级 相同 ， 就 按 router-id 进 行 选 举 ， 由 最 大 
到 次 大 选举 DR、BDR。 


这 里 所 说 的 接口 优先 级 是 由 OSPF 协 议定 义 的 〈 如 Cisco 路 由 器 配置 
接口 优先 级 命令 是 ip ospf priority) ， 可 以 配置 的 优先 级 值 在 0~255 之 间 
(默认 值 为 1， 值 越 大 ， 优 先 级 越 高 ) 。 但 DR、BDR 的 选举 不 支持 抢 
占 (Preemption) ， 也 就 是 一 旦 选举 完成 ， 即 使 新 加 一 个 优先 级 更 高 的 
设备 也 不 会 进行 重新 的 选择 ， 相 反 只 有 在 DR 或 者 BDR 出 问题 的 时 候 才 
会 发 生 重 选 。 就 像 一 个 班 上 已 选举 了 正 、 副 班长 ， 当 新 插入 了 一 个 学 
生 后 ， 也 不 会 重新 选举 班长 ， 即 使 新 来 的 学 生 各 方面 能 力 比 原 班长 、 

副 班 长 强 ， 除 非 原来 的 正 、 副 班长 出 了 问题 。 


9.2.5 ”OSPF LSA 类 型 


OSPF 是 一 种 典型 的 链 路 状态 路 由 协议 ， 默 认 情 况 下 采用 OSPF 的 
每 个 路 由 大 彼此 交换 并 保存 整个 网 络 的 链 路 信息 ， 从 而 擎 握 全 网 的 折 
扑 结构 ， 并 独立 计算 路 由 。 划 分 区 域 后 ，OSPF 路 由 需 收 集 其 所 在 网 络 
区 域 上 各 路 由 名 的 连接 状态 信息 ， 即 链 路 状态 信息 ， 生 成 LSDB。 然 
后 OSPF 路 由 器 利用 SPF 路 由 算法 独立 地 计算 出 到 达 任 意 目 的 地 的 路 
= 


随 着 OSPF 路 由 器 类 型 概念 的 引入 ，OSPF 路 由 协议 又 对 其 链 路 状 
态 通告 (LSA) 数据 包 作 出 了 分 类 。OSPF 将 链 路 状态 通告 数据 包 共 分 
成 以 下 7 类 。 


(1) Type 1: 路 由 器 LSA (Router LSA) 


路 由 器 LSA (第 一 类 通告 ) 可 由 区 域内 所 有 路 由 器 产生 ， 并 且 只 
能 在 本 在 区 域内 泛 洪 通 告 。 路 由 絮 LSA 描 述 了 路 由 絮 物 理 接 口 所 连接 
的 链 路 或 接口 ， 指 明了 链 路 的 状态 、 开 销 等 参数 。 第 一 类 LSA 只 在 产 
生 的 区 域内 泛 洪 。 


(2) Type 2: 网 络 LSA (Network LSA) 


网 络 LSA (第 二 类 通告 ) 是 由 DR (指定 路 由 器 ) 或 者 BDR (备份 
日 定 路 由 器 ) 产生 的 ， 报 文 包括 DR 和 BDR 连 接 的 路 由 器 的 链 路 信息 ， 
描述 了 一 个 多 路 访问 网 络 所 有 相连 的 路 由 套 。 第 二 类 的 LSA 也 只 在 产 
生 的 区 域内 沁 洪 。 


(3) Type 3: 网 络 汇 总 LSA (Network summary LSA) 
网 络 汇总 LSA (第 三 类 通告 ) 是 由 ABR 产生 的 ， 报 文 包 通知 本 区 


域内 的 路 由 器 通 往 区 域外 的 路 由 信息 。 在 一 个 区 域外 部 但 是 仍然 在 一 
个 OSPF 上 自治 系统 内 部 的 默认 路 由 也 可 以 通过 这 种 LSA 来 通告 。 

如 果 一 台 ABR 路 由 器 经 过 骨干 区 域 从 其 他 的 ABR 路 由 器 收 到 多 条 
网 络 汇总 LSA， 那 么 这 台 始 发 的 ABR 路 由 器 将 会 选择 这 些 LSA 通 告 
代价 最 低 的 LSA， 并 且 将 这 个 LSA 的 最 低 代价 通告 给 与 它 相 连 的 非 骨 
干 区 域 。 


(4) Type 4: ASBR 汇 总 LSA (ASBR summary LSA) 


ASBR 汇 总 〈 第 四 类 通告 ) LSA 也 是 由 ABR 发 出 的 ， 但 它 是 一 条 
主机 路 由 ， 即 指向 ASBR 路 由 器 地 址 的 路 由 。 


(5) Type 5: 自治 系统 外 部 LSA (Autonomous system external 


LSA) 


自治 系统 外 部 LSA (第 五 类 通告 ) 是 由 ASBR 产 生 的 ， 告 诉 相同 目 
治 系 统 的 路 由 絮 通 往外 部 目 治 区 的 路 径 。 目 治 系统 外 部 LSA 是 唯一 不 
和 具体 的 区 域 相关 联 的 LSA 通 告 ， 将 在 整个 目 治 系统 中 进行 泛 洪 。 


(6) Type 6: 组 成 员 LSA (Group membership LSA) 


第 六 类 通告 应 用 很 少 ， 且 目前 不 支持 组 播 OSPF (MOSPF) 协 
议 ， 这 类 通告 本 处 不 做 具体 介绍 。 


(7) Type 7: NSSA 外 部 LSA (NSSA External LSA) 


NSSA 外 部 LSA (第 七 类 通告 是 由 ASBR 产 生 的 ， 内 容 和 LSA5 
几乎 是 相同 的 ， 但 NSSA 外 部 LSA 通 告 仅 在 始 发 这 个 NSSA 外 部 LSA 通 
告 的 非 纯 Stub 区 域内 部 进行 泛 洪 。 


在 NSSA 区 域 中 ， 当 有 一 个 路 由 器 是 ASBR 时 ， 不 得 不 产生 LSA5 
报 文 ， 但 是 NSSA 中 不 能 有 LSA 5 报 文 ， 所 有 ASBR 产 生 LSA 7 报 文 ， 发 
给 本 区 域 的 路 由 器 。 只 有 一 个 例外 ， 每 台 ABR 路 由 器 利用 一 个 类 型 3 
来 通告 默认 路 由 。 


Opaque LSA 是 一 个 被 提议 的 LSA 类 别 ， 在 标准 的 LSA 头 部 后 面 加 
上 特殊 应 用 的 信息 组 成 ， 可 以 直接 由 OSPF 协 议 使 用 ,或 者 由 其 他 应 用 
分 发 信息 到 整个 OSPF 域 间接 使 用 。Opaque LSA 分 为 Type9、Type10、 
Typell 三 种 类 型 ， 但 它们 各 自 可 泛 洪 的 区 域 不 同 : 其 中 ，Type9 的 


Opaque LSA 仅 在 本 地 链 路 范围 进行 泛 洪 ，Type10 的 OpaqueLSA 仅 在 本 
地 区 域 范围 进行 泛 洪 ，Type11 的 LSA 可 以 在 一 个 自治 系统 范围 进行 泛 
洪 。 


9.2.6 ”Backbone (骨干 ) 区 域 


在 一 个 大 型 的 OSPF 网 络 中 ， 可 以 包括 多 种 区 域 ， 其 中 就 有 三 种 各 
见 的 特殊 区 域 ， 即 骨干 区 域 (Backbone Area) 、 末 梢 区 域 (Stub 
Area) 和 非 纯 Stub 区 域 (No Stotal Stub area，NSSA) ， 当 然 还 可 以 包 
括 其 他 普通 区 域 。OSPF 网 络 中 的 区 域 是 以 区 域 ID 进 行 标 识 的 ， 区 域 ID 
为 0 的 区 域 规定 为 骨干 区 域 。 这 几 类 区 域 如 图 9-18 所 示 。 本 市 仅 介绍 其 
中 的 骨 王 区域， 其它 类 型 区 域 将 在 本 章 后 面 介 绍 。 


骨干 区 域 


普通 区 域 


Area 3 


Stub 区 域 


图 9-18 OSPF 主要 区 域 类 型 示例 


一 个 OSPF 互 联网 络 ， 无 论 有 没有 划分 区 域 ， 总 征 至 少 有 一 个 骨干 
区 域 。 骨 二 区域 有 一 个 ID 为 0.0.0.0， 称 为 区 域 0。 另 外 ， 和 骨干 区 域 必须 
是 连续 的 〈 也 就 是 中 间 不 会 越过 其 他 区 域 ) ， 其 余 区 域 必须 与 骨干 区 
域 直接 相连 〈 但 事实 上 ， 有 时 并 不 一 定 会 这 样 ， 所 以 也 就 有 了 下 面 将 
要 介绍 的 “虚拟 链 路 ”技术 ) 。 骨 干 区 域 一 般 为 区 域 0 (Area 0) ， 其 主 
要 工作 十 在 其 余 区 域 则 传递 路 由 信息 。 


骨干 区 域 作为 区 域 间 传输 通信 和 分 布 路 由 信息 的 中 心 ， 区 域 间 的 
通信 先 要 被 路 由 到 骨干 区 域 ， 然 后 再 路 由 到 目的 区 域 ， 最 后 被 路 由 到 
目的 区 域 中 的 主机 。 在 骨干 区 域 中 的 路 由 右 通 告 他 们 区 域内 的 汇总 路 
由 到 骨干 区 域 中 的 其 他 路 由 右 。 这 些 汇 忌 通 告 在 区 域内 路 由 此 沁 洪 ， 
所 以 区 域 中 的 每 台 路 由 天 都 有 一 个 反映 其 所 在 区 域内 路 由 可 用 的 路 由 
表 ， 这 个 路 由 与 AS 中 其 他 区 域 的 ABR 汇总 通告 相对 应 。 


如 在 图 9-14 所 示 的 OSPF 网 络 中 ，R1 使 用 一 个 汇总 通告 向 所 有 骨干 
路 由 器 (R2 和 R3) 通告 Area 0.0.0.1 中 的 所 有 路 由 。R1 从 R2 和 R3 接 收 汇 
总 通告 。R1 配 置 了 Area 0.0.0.0 中 的 汇总 通告 信息 ， 通 过 沁 洪 ，R1 把 这 
个 汇总 路 由 信息 传播 到 Area 0.0.0.1 内 所 有 路 由 器 上 “。 在 Area 0.0.0.1 内 的 
每 个 路 由 器 ， 依 据 来 自 Areas 0.0.0.0、0.0.0.2 和 0.0.0.3 区 域 的 汇总 路 由 信 
息 完成 路 由 表 的 计算 。 


在 实际 网 络 中 ， 可 能 会 存在 骨干 区 域 不 连续 ， 或 者 某 一 个 区 域 与 
骨干 区 域 物理 不 相连 的 情况 ， 此 时 系统 管理 员 可 以 通过 设置 虚拟 链 路 


(Virtual Link) 的 方法 来 解决 该 问题 (参见 图 9-18 中 Area 1 中 的 “虚拟 链 
路 ”) 。 虚 拟 链 路 存在 于 两 个 路 由 器 之 间 ， 这 两 个 路 由 器 都 有 一 个 端口 
与 同一 个 非 骨 干 区域 (这 个 区 域 是 处 于 骨干 区 域 和 有 某 个 不 直接 与 骨干 
区 域 相 连 的 区 域 之 间 ) 相连 ， 虚 拟 链 路 使 该 区 域 与 骨干 区 域 间 建立 一 
个 逻 神 连接 点 。 


虚拟 链 路 被 认为 属于 骨干 区 域 (相当 于 骨干 区 域 的 延伸 ) ， 在 
OSPF 路 由 协议 看 来 ， 虚 拟 链 路 两 半 的 两 个 路 由 右 被 一 个 点 对 点 的 通路 
连 在 一 起 ， 这 样 原来 本 来 没有 与 骨干 区 域 连接 的 区 域 束 变 成 直接 连 
接 ， 成 为 普通 区 域 了 。 而 且 ， 在 OSPF 路 由 协议 中 ， 通 过 虚拟 链 路 的 路 
由 信息 是 作为 域内 路 由 来 看 待 的 。 但 是 ， 该 虚拟 链 路 必须 建立 在 两 个 
区 域 边界 路 由 郁 之 间 ， 并 且 有 其 中 一 个 区 域 边 界 路 由 融 必 须 属于 骨干 区 
域 。 


9.2.7 Stub 《来 梢 ) 区 域 


通过 前 面 对 OSPF 区 域 概念 的 了 解 可 以 知道 ， 在 划分 了 区 域 之 后 ， 
OSPF 网 络 中 的 非 骨 干 区 域 中 的 路 由 亏 要 路 由 到 外 部 区 域 ， 一 定 要 通过 
ABR (区 域 边界 路 由 器 ) 来 转发 。 或 者 说 对 于 区 域内 的 路 由 器 来 说 ， 
ABR 十 一 个 通 往外 部 区 域 的 必 经 之 路 。 既 然 如 此 ， 对 于 区 域内 的 路 由 
右 来 说 ， 就 没有 必要 知道 通 往 外 部 区 域 的 详细 路 由 了 ， 只 要 由 ABR 问 
该 区 域 发 布 一 条 默认 路 由 来 告知 报 文 的 发 送 路 径 即 可 。 这 样 在 区 域内 
的 路 由 器 中 束 只 需要 为 数 不 多 的 区 域内 路 由 和 一 条 指向 ABR 的 默认 路 
由 即 可 ,使 区 域内 的 路 由 表 和 人 简化。 而 且 无 论 区 域外 的 路 由 如 何 变 化 ， 
都 不 会 影响 到 区 域内 路 由 器 这 个 简单 的 路 由 表 。 这 就 是 OSPF 路 由 协议 
中 “Stub Area” 《末梢 区 域 ) 的 设计 理念 。 


Stub 区 域 是 一 种 比较 特殊 的 区 域 ， 该 区 域 的 ABR 不 能 接收 其 他 
OSPF AS 路 由 ， 因 为 该 区 域 中 不 存在 ASBR。 在 Stub 区 域 的 内 部 路 由 器 
仅 需 要 配置 一 条 到 达 该 区 域 ABR 的 默认 路 由 (0.0.0.0 0.0.0.0) 来 实现 
同一 AS 中 不 同 区 域 间 的 路 由 ， 这 样 可 使 得 这 些 区 域 中 内 部 路 由 器 的 路 
由 表 规 模 以 及 路 由 信息 传递 的 数量 都 会 大 大 减少 。 但 要 注意 的 是 ， 并 
不 是 每 个 区 域 都 可 以 配置 为 Stub 区 域 ， 也 就 是 说 要 配置 为 Stub 区 域 还 
需 符合 一 定 的 条 件 。 具 体 来 说 配置 为 Stub 区 域 具有 以 下 特点 : 


口 Stub 区 域 位 于 AS 的 边界 ， 是 那些 只 有 一 个 ABR 的 非 骨 干 区 域 。 
为 剑 证 到 AS 内 其 他 区 域 的 路 由 依旧 可 达 ， 该 区 域 的 ABR 将 生成 一 条 默 
认 路 由 ， 并 发 布 给 Stub 区 域 中 的 其 他 非 ABR 路 由 器 。 


口 骨 干 区 域 不 能 配置 成 Stub 区 域 。 


口 Stub 区 域内 不 能 存在 ASBR， 即 目 治 系统 外 部 的 路 由 不 能 在 该 区 
域内 传播 。 


口 虚 连接 不 能 穿 过 Stub 区 域 。 


在 Stub 区 域 中 的 各 路 由 器 上 所 创建 的 默认 路 由 是 用 于 Stub 区 域 中 
各 路 由 器 为 任 一 不 可 到 达 AS 内 部 的 外 部 耳 地 址 提供 的 唯一 路 由 。 在 
Stub 区 域 中 的 所 有 路 由 器 必须 被 配置 为 该 默认 路 由 ， 以 便 它 们 不 在 
Stub 区 域内 导入 或 泛 洪 AS 外 部 路 由 。 所 以 ， 在 一 个 Stub 区 域 中 的 所 有 
路 由 器 接口 上 的 所 有 区 域 配置 必须 配置 Stub 区 域 。 例 如 ， 图 9-19 中 的 
Area 0.0.0.3 被 配置 为 一 个 Stub 区 域 ， 因 为 所 有 外 部 通信 必须 通过 它 的 
单个 ABR 一 一 R3 到 达 。R3 通 告 一 个 默认 路 由 分 布 在 内 部 区 域 Area 
0.0.0.3， 但 不 会 在 区 域内 泛 洪 AS 外 部 区 域 路 由 。 


一 个 AS 外 部 路 由 器 
ASBR 


Area 0.0.0.0 


py ST 


Stub Area R 


9-19 ”OSPF Stub 区 域 示 例 


由 于 Stub 区 域 通 第 位 于 OSPF 网 络 末 端 ， 这 些 区 域内 的 路 由 胡 通 党 
由 一 些 处 理 能 力 有 限 的 低 端 路 由 天 组 成 ， 所 以 处 于 Stub 区 域内 的 这 
低 端 设备 既 不 需要 保存 庞大 的 路 由 表 ， 也 不 需要 经 党 性 地 进行 路 由 
计算 。 这 样 做 有 利于 减 小 Stub 区 域 中 内 部 路 由 右上 的 链 路 状态 数据 库 
的 大 小 及 存储 右 的 使 用 ， 提 高 路 由 右 计 算 路 由 表 的 速度 。 


是 
此 


当 一 个 OSPF 的 区 域 只 存在 一 个 区 域 出 口 点 (只 与 一 个 其 他 区 域 连 
接 ) 时 ， 我 们 可 以 将 该 区 域 配置 成 一 个 Stub 区 域 。 这 时 ， 该 区 域 的 边 
界 路 由 融会 对 域内 通告 默认 路 由 信息 。 需 要 注意 的 是 ， 一 个 Stub 区 域 


中 的 所 有 路 由 器 都 必须 知道 自身 属于 该 区 域 也 就 是 需要 在 其 中 的 路 
由 器 中 局 用 这 项 功能 ) ， 否 则 Stub 区 域 的 设置 不 会 起 作用 。 


9.2.8 Totally Stub 区 域 和 NSSA 区 域 


上 节 介 绍 的 Stub 区 域 是 一 类 特殊 的 OSPF 区 域 ， 这 类 区 域 不 接收 或 
扩散 Type 5 类 型 LSA (AS 外 部 LSA) ， 对 于 产生 大 量 Type 5 LSA 的 网 
络 ， 这 种 处 理 方式 能 够 有 效 减 小 Stub 区 域内 路 由 器 的 LSDB 大 小 ， 并 绥 
解 SPF 运 算 对 路 由 器 资源 的 占用 。 通 常情 况 下 ，Stub 区 域 位 于 上 自治 系统 
边缘 区 域 。 为 保证 Stub 区 域 去 往 自 治 系统 外 的 报 文 能 被 正确 转发 ，Stub 
区 域 的 ABR (区 域 边界 路 由 器 ) 将 通过 Summary-LSA (汇总 链 路 状态 
通告 ) 向 本 区 域内 发 布 一 条 默认 路 由 ， 并 且 只 在 本 区 域 泛 洪 。 为 了 进 
一 步 减 少 Stub 区 域 中 路 由 器 的 路 由 表 规模 以 及 路 由 信息 传递 的 数量 ， 

可 以 将 该 区 域 配置 为 Totally Stub (完全 末梢 ) 区 域 ， 该 区 域 的 ABR 不 
会 将 区 域 间 的 路 由 信息 和 外 部 路 由 信息 传递 到 本 区 域 。 


1. 完 全 Stub 区 域 


这 里 所 说 的 完全 Stub 区 域 (Totally Stub， 或 者 Stub no-summary) 
是 在 Stub 区 域 的 基础 上 ( 即 阻止 了 Type 5 LSA 包 的 基础 上 ) 再 阻止 其 
他 ABR 通 告 的 网 络 汇 总 LSA ( 即 Type 3 类 型 LSA) ， 不 接收 区 域 间 路 由 
通告 。 其 ABR 仅 通过 网 络 汇总 LSA 通 告 一 个 默认 路 由 ， 使 用 这 个 默认 
路 由 可 到 达 OSPF 上 自治 系统 外 部 其 他 区 域 。 也 就 是 说 ， 完 全 Stub 区 域 同 
时 不 允许 Type 3、4 或 5 三 类 LSA 注 入 ， 但 默认 汇总 路 由 除外 。 


2.NSSA 区 域 


Stub 区 域 虽 然 为 合理 地 规划 网 络 描绘 了 美好 的 前 景 ， 但 在 实际 的 
组 网 中 利用 率 并 不 高 (Stub 区 域 一 般 只 存在 于 网 络 边缘 ) ， 未 免 遗 
憾 。 但 此 时 的 OSPF 协 议 已 经 基本 成 型 ， 不 可 能 再 做 大 的 修改 。 为 了 弥 
补缺 陷 ， 协 议 设 计 者 提出 了 一 种 新 的 概念 NSSA (not-so-Stubby area， 
非 纯 末梢 区 域 '， 并 且 作 为 OSPF 协 议 的 一 种 扩展 属性 单独 在 RFC 1587 
中 描述 。NSSA 对 原来 的 Stub 区 域 要 求 有 所 放宽 ， 使 它 可 以 在 更 多 网 络 
环境 中 得 到 应 用 。 


NSSA 区 域 规定 ，AS 外 的 ASE (AS 外 部 ) 路 由 不 可 以 进入 到 NSSA 
区 域 中 ， 但 是 NSSA 区 域内 的 路 由 器 引入 的 ASE 路 由 (NSSA 区 域 中 可 
以 连接 ASBR) 可 以 在 NSSA 中 泛 洪 并 发 送 到 区 域 之 外 。 这 样 ， 在 
NSSA 区 域 中 取消 了 原来 Stub 区 域 中 关于 ASE 的 双向 传播 的 限制 《区 域 
外 的 进 不 来 ， 区 域 里 的 也 出 不 去 ) ， 改 为 单 向 限制 (区 域外 的 进 不 
来 ， 区 域 里 的 能 出 去 ) 。 


图 9-20 所 示 是 一 个 包含 NSSA 区 域 的 OSPF 网 络 示 例 。NSSA 所 对 应 
的 区 域 ID 为 1， 与 骨干 区 域 0 相 连 ; 同时 它 又 与 IGRP 和 RIP 路 由 协议 这 
两 个 不 同 的 AS 相连 。 此 时 ， 外 部 区 域 和 外 部 AS 的 路 由 信息 不 能 通告 到 
NSSA 区 域 中 ， 但 NSSA 中 的 路 由 信息 可 以 向 外 发 布 。 


9-20 ”OSPF NSSA 区 域 示 例 


为 了 解决 ASE 单 向 传递 的 问题 ，NSSA 中 重新 定义 了 一 种 LSA 一 一 
Type 7 类 型 的 LSA (NSSA 外 部 LSA) ， 供 区 域内 的 路 由 器 引入 外 部 路 
由 时 使 用 。 该 类 型 的 LSA 除 了 类 型 标识 与 Type 5 不 相同 之 外 ， 其 他 内 容 
基本 一 样 。 这 样 区 域内 的 路 由 器 就 可 以 通过 LSA 的 类 型 来 判断 是 否 该 
路 由 来 自 本 区 域内 。 但 由 于 Type 7 类 的 LSA 是 新 定义 的 ， 对 于 不 支持 
NSSA 属 性 的 路 由 器 无 法 识别 ， 所 以 协议 规定 : 在 NSSA 的 ABR 上 将 
NSSA 内 部 产生 的 Type 7 类 型 的 LSA 转 化 为 Type 5 类 型 的 LSA 再 发 布 出 
去 ， 并 同时 更 改 LSA 的 发 布 者 为 ABR 自己 。 这 样 NSSA 区 域外 的 路 由 器 
就 可 以 完全 不 用 支持 该 属性 。 在 NSSA 区 域内 的 所 有 路 由 器 (包括 
NSSA 的 ABR) 必须 支持 Type 7 类 型 的 LSA 属 性 ， 而 自治 系统 中 的 其 他 
路 由 器 则 不 需要 。 


总 的 来 说 ，NSSA 区 域 不 允许 Type5LSA， 但 在 NSSA ABR 上 转换 
为 Type 5 的 Type7LSA 还 是 可 以 通过 的 。 


9.2.9 ” OSPF 路 由 计算 基本 过 程 


在 OSPF 网 络 ， 路 由 的 计算 不 是 简单 地 把 源 地 址 与 目的 地 址 进行 天 
联 ， 需 要 考虑 到 许多 因素 ， 以 确定 一 条 最 佳 路 径 。 整 个 OSPF 路 由 计算 
过 程 可 分 为 : 邻接 关系 建立 ~ DR/BDR 选 举 - 发 送 LSA-~ 创建 路 由 表 
”维护 路 由 表 这 五 大 基本 步 又 。 有 具体 摘 述 如 下 。 


(1) 建立 邻接 关系 


所 谓 “ 邻 接 关 系 ”(Adjacency) 是 指 OSPF 路 由 器 以 交换 路 由 信息 
为 目的 ， 在 所 选择 的 相 邻 路 由 器 之 间 建 立 的 一 种 关系 。 在 OSPF 中 ， 邻 
居 (Neighbor) 和 邻接 (Adjacency) 是 两 个 不 同 的 概念 。OSPF 路 由 器 
局 动 后 ， 便 会 通过 OSPF 接 口 同 外 发 送 Hello 报 文 。 收 到 Hello 报 文 的 
OSPF 路 由 器 会 检查 报 文中 所 定义 的 参数 ， 如 果 双 方 一 致 就 会 形成 邻居 
关系 。 但 形成 邻居 关系 的 双方 不 一 定 都 能 形成 邻接 关系 ， 这 要 根据 网 
络 类 型 而 定 。 只 有 当 双 方 成 功 交 换 DD (Database Description， 数 据 库 
描述 ) 报 文 ， 交 换 LSA 并 达到 LSDB 的 同步 之 后 ， 才 形成 真正 意义 上 的 
邻接 关系 。 


具体 步骤 是 : 路 由 器 首先 发 送 拥 有 上 自身 ID 信息 (Loopback 喘 口 或 
最 大 的 IP 地 址 ) 的 Hello 报 文 。 与 之 相 邻 的 路 由 器 如 果 收 到 这 个 Hello 报 
文 ， 就 将 这 个 报 文 内 的 ID 信息 加 入 到 自己 的 Hello 报 文 内 。 然 后 在 后 面 


发 送 的 Hello 报 文中 就 包括 了 原来 所 接收 到 的 邻居 路 由 器 的 ID 信息 。 如 
林 路 由 融 的 某 端口 收 到 从 其 他 路 由 顺 发 送 的 含有 目 身 ID 信息 的 Hello 报 
文 ， 则 它 根据 该 端口 所 在 网 络 类 型 确定 是 否 可 以 与 对 站 路 由 絮 建 立 邻 
接 大 系 。 


在 点 对 点 网 络 中 ， 路 由 器 将 直接 和 对 闻 路 由 器 建立 起 邻接 关系 ， 
并 且 该 路 由 器 将 直接 进入 到 下 面 的 第 3 步 ， 发 送 LSA 以 发 现 其 他 路 由 
右 ; 寿 为 多 路 访问 网 络 , 则 该 路 由 器 将 进入 下 面 第 2 步 。 


(2) 选举 DR/BDR 


在 广播 或 者 多 路 访问 OSPF 网 络 中 ， 各 相 邻 路 由 器 都 建立 了 相 邻 关 
系 后 ， 就 要 选举 一 个 担当 区 域内 的 LSU 通 告 代理 角色 的 DR (指定 路 由 
) 和 BDR 《备份 指定 路 由 器 ) ， 因 为 在 OSPF 网 络 中 ， 为 了 减少 LSU 
告 的 流量 ， 各 路 由 器 之 间 不 直接 发 送 链 路 状态 信息 ， 而 是 通过 选举 
DR/BDR 进 行 统一 分 发 。 其 他 路 由 器 要 发 送 LSU， 则 先 把 LSU 发 给 
DR/BDR， 再 由 DR 或 者 BDR (只 有 在 DR 失效 时 才 使 用 它 ) 在 组 播 给 
所 有 非 DR 或 者 BDR 的 路 由 器 。 


器 


Ex 


DR 和 BDR 是 由 同一 网 段 中 所 有 的 路 由 器 根据 路 由 屁 优 先 级 、 
Router ID 通 过 Hello 报 文 移 举 出 来 的 ， 只 有 优先 级 大 于 0 的 路 由 器 才 具 
有 选举 资格 。 具 体 的 选举 过 程 如 下 : 


1) 在 与 一 个 或 多 个 邻居 之 间 的 双向 通信 建立 起 来 之 后 ， 本 地 路 由 
器 对 每 个 邻居 发 送 来 的 Hello 包 中 的 优先 级 、DR 和 BDR 域 进行 检查 。 
此 时 所 有 路 由 器 都 宣称 自己 为 DR (将 它们 自己 的 接口 地 址 置 于 Hello 
包 的 DR 域 中 ) ;而 且 所 有 路 由 器 都 宣称 自己 为 BDR (将 它们 自己 的 接 
口 地 址 置 于 Hello 包 的 BDR 域 中 ) 。 


2) 如 果 一 或 多 个 备 选 路 由 器 将 它 ( 们 ) 上 自身 的 接口 地 址 置 于 DR 
域 中 ， 拥 有 最 高 优先 级 的 邻居 将 被 宣告 为 DR。 如 末路 由 需 优 先 级 一 
样 ， 拥 有 最 高 Router ID 的 邻居 将 被 选举 出 来 。 


3) 然后 在 将 自身 的 接口 地 址 置 于 BDR 域 中 的 路 由 器 中 选择 拥有 
最 高 优先 级 的 路 由 器 作为 BDR。 如 果 这 些 宣 称 目 己 为 BDR 路 由 需 的 优 
先 级 相等 ， 则 拥有 最 高 Router ID 的 邻居 将 被 选举 作为 BDR。 


4) 如 果 没 有 任何 路 由 器 被 宣告 为 BDR， 则 拥有 最 高 优先 级 的 非 
DR 邻居 路 由 器 将 被 选举 为 BDR; 如 果 多 个 这 样 的 路 由 器 优先 级 相同 ， 
则 拥有 最 高 Router ID 的 邻居 将 被 选举 为 BDR 。 


(3) 发 送 LSA 


作为 一 种 典型 的 链 路 状态 的 路 由 协议 ，OSPF 还 得 遵循 链 路 状态 路 

由 协议 的 统一 算法 。 当 路 由 器 初始 化 或 当 网 络 结构 发 生变 化 (例如 增 
减 路 由 器 ， 链 路 状态 发 生变 化 等 ) 时 ， 路 由 器 会 产生 链 路 状态 广播 

(LSA) 数据 包 ， 该 数据 包 里 包含 路 由 器 上 所 有 相连 链 路 ， 也 即 为 所 


有 端口 的 状态 信息 。 所 有 路 由 需 会 通过 泛 洪 方式 来 交换 链 路 状态 数 
人 


在 这 步 ， 路 由 器 与 路 由 器 之 间 前 先 利用 Hello 报 文 的 ID 信 息 确 认 主 
从 关系 ， 然 后 主 从 路 由 右 相 互 交 换 部 分 链 路 状态 信息 。 每 个 路 由 器 对 
言 尽 进 行 分 析 比 较 ， 如 有 果 收 到 的 信息 有 新 的 内 容 ， 路 由 侣 将 要 求 对 方 
发 送 完整 的 链 路 状态 信息 。 这 个 状态 完成 后 ， 路 由 絮 之 间 建 并 完全 令 
接 天 系 ， 同 时 各 邻接 路 由 器 拥有 目 己 独立 的 、 完 整 的 链 路 状态 数据 
库 。 


在 多 路 访问 网 络 内 ，DR 与 BDR 互 换 信息 ， 并 同时 与 本 子 网 内 其 他 
路 由 器 交换 链 路 状态 信息 。 在 点 对 点 或 点 对 多 点 网 络 中 ， 相 邻 路 由 器 
之 间 会 直接 交换 链 路 状态 信息 。 


(4) 创建 路 由 表 


当 网 络 重新 稳定 下 来 ， 也 可 以 说 OSPF 路 由 协议 收敛 下 来 时 ， 所 有 
的 路 由 器 会 根据 其 各 目的 链 路 状态 信息 数据 库 采 用 SPF (最 短路 径 优 
先 ) 算法 计算 并 创建 路 由 表 。OSPF 路 由 器 依据 链 路 状态 数据 库 的 内 
容 ， 独 立地 用 SPF 算 法 计算 出 到 每 一 个 目的 网 络 的 路 径 ， 并 将 路 径 存 
入 路 由 表 中 。 该 路 由 表 中 包含 路 由 需 到 每 一 个 可 到 达 目 的 地 的 开销 以 
及 到 达 该 目的 地 所 要 转发 的 下 一 个 路 由 器 (next-hop) 。 


OSPF 利 用 开销 来 计算 路 由 路 径 性 能 的 ， 开 销 最 小 者 即 为 最 短路 
径 。 在 配置 OSPF 路 由 器 时 可 根据 实际 情况 ， 如 链 路 市 完 、 时 延 等 设置 
链 路 的 开销 大 小 ;开销 越 小 ， 则 该 链 路 被 选 为 路 由 的 可 能 性 越 大 。 这 
里 的 开销 是 根据 链 路 类 型 来 计算 的 ， 不 同 的 链 路 类 型 对 应 的 开销 值 不 
= 


(5) 维护 路 由 信息 


当 链 路 状态 发 生变 化 时 ，OSPF 通 过 泛 洪 过 程 广播 网 络 上 的 其 他 路 
由 右 。OSPF 路 由 虽 接 收 到 包含 有 新 信息 的 链 路 状态 更 新 报 文 ， 将 更 新 
自己 的 链 路 状态 数据 库 ， 然 后 用 SPF 算 法 重新 计算 路 由 表 。 在 重新 计 
算 过 程 中 ， 路 由 器 继续 使 用 旧 路 由 表 ， 直 到 SPF 完 成 新 的 路 由 表 计 
算 。 新 的 链 路 状态 信息 将 发 送 给 其 他 路 由 器 。 值 得 注意 的 是 ， 即 使 链 
路 状态 没有 发 生 改 变 ，OSPF 路 由 信息 也 会 目 动 更 新 ， 默 认 时 间 为 


30min ° 


9.2.10 ”OSPF 报 头 格式 


OSPF 报 文 直接 封 狂 为 IP 协 议 报 文 ， 因 为 OSPF 是 专 为 TCP/IP 网 络 而 
设计 的 路 由 协议 。OSPF 报 文 主要 有 5 种 : Hello 报 文 、DD (Database 
Description， 数 据 库 描述 ) 报 文 、LSR (Link State Request， 链 路 状态 
请 求 ) 报 文 、LSU (Link State Update， 链 路 状态 更 新 ) 报 文 和 LSAck 

(Link State Acknowledgment， 链 路 状态 应 答 ) 报 文 。 它 们 使 用 相同 的 
OSPF 报 头 格 式 ， 如 图 9-21 所 示 。 


< 1 二 1 一 一 一 2 一 一 | 字 节 


Verslon 


Packet Type Packet Length 


Router ID 


Area [ID 


Checksum 


AuType 


Authentication 


图 9-21 OSPF 协 议 报头 格式 
(1) Version 


版 本 字段 ， 占 1 字 节 ， 指 出 所 采用 的 OSPF 协 议 版 本 号 ， 目 前 最 高 
版 本 为 OSPF v4， 即 值 为 4 (对 应 二 进 制 就 是 0100) 。 


(2) Packet Type 


报 文 类 型 字段 ， 标 识 对 应 报 文 的 类 型 。 前 面 说 了 OSPF 有 5 种 报 
> 别 是 : Hello 报 文 、DD 报 文 、LSR 报 文 、LSU 报 文 、LSAck 报 


ps 
文 。 这 五 种 类 型 字段 解释 如 下 。 


1) Hello 报 文 : OSPF Hello 报 文 是 用 来 发 现 OSPF 邻 居 并 维持 OSPF 
邻居 关系 的 报 文 。Hello 报 文 被 周期 地 发 向 邻居 路 由 器 接口 发 送 ， 报 文 
内 容 包 括 一 些 定 时 器 设置 、 DR、BDR 以 及 本 路 由 器 已 知 的 邻居 路 由 
器 o 

整个 Hello 报 文 格式 如 图 9-22 所 示 ， 上 部 分 为 图 9-21 所 示 的 OSPF 报 


头 部 分 ， 下 部 分 为 Hello 报 文 内 容 部 分 。Hello 报 文 内 容 部 分 各 字段 说 明 
如 表 9-1 所 示 。 


0 7 15 31 位 
Packet length 


Version 
Router ID 
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报头 Checksum AuType 


部 分 


Authentication 
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HelloInterval Options Rtr Pri 
RouterDeadInterval 
Hello 和 
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部 分 Backup Designated Router 


| Neighbor 


图 9-22 ”Hello 报 文 格式 


表 9-1 Hello 报 文 内 容 部 分 字段 说 明 


字段 名 功 能 
Network Mask 发 送 Hello 报 文 接口 所 在 的 子 网 推 码 
Hellolnterval 指定 发 送 Hello 报 文 的 时 间 间 隔 ， 默 认为 10s 


可 选项 ， 包 括 E， 人 允许 泛 洪 AS-external-LAS ; MC， 人 允许 转发 IP 组 
播报 文 ，N/P， 人 允许 处 理 Type 7 LSA; DC， 人 允许 处 理 按 需 链 路 


i | | 指定 DR 优先 级 ， 默 认为 1。 如果 设 为 0， 则 表示 本 路 由 器 不 参与 


Options 


DR/BDR 选举 
指定 路 由 器 失效 时 间 ， 默 认为 40s。 如 果 在 此 时 间 内 没有 收 到 邻居 路 
由 器 发 来 的 Hello 报 文 ， 则 认为 该 邻居 路 由 器 已 失效 


Designated Router 指定 DR 的 接口 IP 地 址 


RouterDeadInterval 


字段 名 


Backup Designated Router 


功 能 
指定 BDR 的 接口 IP 地 址 


指定 邻居 路 由 器 的 RID。 下 面 的 省 略 号 (…) 表示 可 以 指定 多 个 邻 


Neighb， 
居 路 由 器 RID 


2) DD 报 文 : DD 报 文 是 用 来 描述 本 路 由 器 的 链 路 状态 数据 库 
(LSDB) ， 进 行 数据 库 同步 的 。DD 报 文 内 容 部 分 包括 DD 报 文 序列 号 
和 LSDB 中 每 一 条 LSA 的 头 部 等 ， 如 图 9-23 所 示 。 各 字段 说 明 如 表 9-2 所 


修 ° 


0 7 15 31 位 
Version Type=2 Packet length 
Router ID 
OSPF Area ID 
报关 ee 
部 分 
Authentication 
Network Mask 
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内 容 部 分 DD Sequence Number 
LSA Headers .… 


图 。9-23 DD 报 文 格式 


表 9-2 DD 报 文 内 容 部 分 字段 说 明 


字段 名 功 能 


Interface MTU 指出 发 送 DD 报 文 的 接口 在 不 分 段 的 情况 下 ， 可 以 发 出 的 最 大 IP 报 文 长 度 


Options 1 字 节 可 选项 ， 包 括 E: 允许 证 浴 AS-external-LAS; MC， 人 允许 转发 IP 组 播报 文 ; 
Oe | N/P， 人 允许 处 理 Type 7 LSA: DC， 人 允许 处 理 按 需 链 路 

j 指定 在 连续 发 送 多 个 DD 报 文 ， 如 果 是 第 一 个 DD 报 文 则 置 1， 其 他 的 均 
攻 置 0 

Nf 指定 在 连续 发 送 多 个 DD 报 文 ， 如 果 是 最 后 一 个 DD 报 文 则 置 0， 否 则 均 
置 

M/S 设置 进行 DD 报 文 双方 的 主 从 关系 ， 如 果 本 端 是 Master 角色 ， 则 置 1， 否 

i 则 置 0 


NR 、 5 指定 所 发 送 的 DD 报 文 序列 号 。 主 从 双方 利用 序列 号 来 确保 DD 报 文 传输 
DD Sequence Number 的 可 靠 性 和 完整 性 


指定 DD 报 文中 所 包括 的 LSA 头 部 。 后 面 的 省 略 号 〔(…) 表示 可 以 指定 多 


LSA Header 个 LSA 头 部 


对 端 路 由 句 根 据 所 收 到 的 DD 报 文中 的 OSPF 报 头 束 可 以 判断 出 是 否 
已 有 这 条 LSA。 在 DD 报 文 交换 中 ， 一 台 为 Master ( 主 ) 角色 ， 另 一 台 
为 Slave (从 ) 角色 。Master 规 定 起 始 序列 号 ， 每 发 送 一 个 DD 报 文 ， 序 
列 号 加 1，Slave 则 使 用 Master 的 序列 号 进行 确定 应 答 。 


3) LSR 报 文 : 当 两 台 路 由 器 互相 交换 完 DD 报 文 后 ， 知 道 对 端 路 由 
强 有 哪些 LSA 是 本 LSDB 所 没有 的 ， 以 及 哪些 LSA 是 已 经 失效 的 ， 则 需 
要 发 送 一 个 LSR 报 文 ， 向 对 方 请 求 所 需 的 LSA。LSR 报 文 内 容 包 括 所 需 
的 LSA 摘 要 ， 具 体格 式 如 图 9-24 所 示 ，LSR 报 文 内 容 部 分 各 字段 说 明 如 
表 9-3 所 示 。 
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Authentication 
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LSR 报 文 Link State ID 
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图 9-24 LSR 报 文 格式 
表 9-3 LSR 报 文 内 容 部 分 字段 说 明 
字段 名 攻 度 / 字 节 功 能 
LS type 指定 所 请 求 的 LSA 类 型 ， 主 要 共 7 类， 具体 参见 9.2.5 节 
用 于 指定 ospf 所 描述 的 部 分 区 域 ， 该 字段 的 使 用 方法 根据 不 同 的 LSA 类 型 
而 不 同 : 当 为 LSA 1 时 ， 该 字段 值 是 产生 LSA 1 的 路 由 器 的 Router ID ; 当 为 
Link State ID 4 LSA 2 时 ， 该 字段 值 是 DR 的 接口 地 址 ， 当 为 LSA 3 时 ， 该 字段 值 是 目的 网 络 


的 网 络 地 址 ， 当 为 LSA 4 时 ， 该 字段 值 是 ASBR 的 Router ID; 当 为 LSA5 时 ， 
该 字段 值 是 目的 网 络 的 网 络 地 址 
Advertising Router 指定 产生 此 请 求 LSA 的 路 由 器 ID 


4) LSU 报 文 : LSU 报 文 是 用 来 向 对 端 路 由 器 发 送 所 需 的 LSA， 内 
容 是 多 条 LSA 完 整 内 容 的 集合 ，LSU 报 文 内 容 部 分 包括 此 次 共 发 送 的 
LSA 数 量 和 每 条 LSA 的 完整 内 容 ， 如 图 9-25， 报 文 内 容 部 分 的 两 个 字段 
如 表 9-4 所 示 。 
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图 9-25 ”LSU 报 文 格式 


表 9-4 LSU 报 文 内 容 部 分 字段 说 明 


字段 名 功 能 
Number of LSAs 间 定 此 报 文 中 共 发 送 的 LSA 数量 
LSAs 是 一 条 条 有 具体 的 LSA 完整 信息 ， 后 面 的 省 略 号 表示 可 多 条 LSA 


LSU 报 文 在 文 持 组 播 和 多 路 访问 的 链 路 上 是 以 组 播 方 式 将 LSA 沁 洪 
出 去 的 ， 并 且 对 没有 收 到 对 方 确 认 应 答 (就 是 下 面 将 要 介绍 的 LSAck 报 
文 ) 的 LSA 进 行 重 传 ， 但 重 传 时 的 LSA 是 直接 送 到 没有 收 到 确认 应 答 的 
邻居 路 由 事 上 ， 而 不 再 十 泛 洪 。 


5) LSAck 报 文 : 这 是 路 由 需 在 收 到 对 端 发 来 的 LSU 报 文 后 所 发 出 
的 确认 应 答 报 文 ， 内 容 是 需要 确认 的 LSA 头 部 (LSA Headers) ， 整 个 
LSAck 报 文 的 格式 如 图 9-26 所 示 。LSAck 报 文 根 据 不 同 链 路 以 单 播 或 组 
播 形 式 发 送 。 
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图 9-26 LSAck 报 文 格式 
下 面 继 续 介绍 图 9-21 中 所 示 的 其 他 OSPF 报 头 字 段 。 


口 Packet Length: 包 长 度 字 段 ， 占 2 字 节 。 它 是 指 整个 报 文 (包括 
OSPF 报 头 部 分 和 后 面 各 报 文 内 容 部 分 ) 的 字 贡 长度。 


口 Router ID: 路 由 器 ID 字段 ， 占 4 字 节 ， 指 定 发 送 报 文 的 源 路 由 器 
ID 。 


口 Area ID: 区 域 ID 字段 ， 占 4 字 节 ， 指 定 发 送 报 文 的 路 由 器 所 对 应 
的 OSPF 区 域 号 。 


口 Checksum: 校 验 和 字段 ， 占 2 字 节 ， 是 对 整个 报 文 (包括 OSPF 
报头 和 各 报 文 具体 内 容 ， 但 不 包括 下 面 的 Authentication 字 段 ) 的 校 验 
和 ， 用 于 对 端 路 由 需 校 验 报 文 的 完整 性 和 正确 性 。 


口 AuType， 认 证 类 型 字段 ， 占 2 字 节 ， 指 定 所 采用 的 认证 类 型 ，0 
为 不 认证 ， 1 为 进行 简单 认证 ，2 采 用 MD5 方 式 认证 。 


口 Authentication: 认证 字段 ， 占 8 字 节 ， 具 体 值 根据 不 同 认证 类 型 
而 定 。 认 证 类 型 为 不 认证 时 ， 此 字段 没有 数据 ; 认证 类 型 为 简单 认证 
上 时， 此 字段 为 认证 密码 ;认证 类 型 为 MD5 认 证 时 ， 此 字段 为 MD5 摘 要 


NMA] Pa 
消息 。 


9.3 ”IS-IS 路 由 协议 


IS-IS (Intermediate System-to-Intermediate System， 中 间 系 统 到 中 
间 系 统 ) 是 一 个 链 路 状态 内 部 网 关 协 议 (Interior Gateway Protocol， 
IGP) ， 是 OSURM 协 议 栈 中 CLNS (Connectionless Network Service， 
无 连接 网 络 服务 ) 的 一 部 分 。 我 们 知道 ， 链 路 状态 协议 的 特点 束 是 信 
轧 的 传播 需要 在 每 个 参与 路 由 协议 的 路 由 硕 上 构建 一 个 完整 的 网 络 互 
连 映 射 。 这 个 映 映 是 用 来 计算 到 达 目 的 节点 或 网 络 的 最 短路 径 的 。 


9.3.1 ISO 网 络 基 础 


在 OSVRM 体 系 结构 的 ISO 网 络 中 ， 定 义 了 两 类 网 络 层 服务 : 
CLNS (Connectionless Network Service， 无 连接 网 络 服务 ) 和 CONS 
(Connection-oriented Network Service， 面 向 连接 的 网 络 服 务 ) 。 提 供 
CLNS 服 务 的 网 络 连接 协议 称 为 CLNP (Connectionless Network 
Protocol， 无 连接 网 络 协议 ) ， 类 似 于 TCP/IP 协 议 网 络 中 的 IP 协 议 ， 都 
是 无 连接 的 网 络 层 协 议 。 提 供 CONS 服 务 的 网 络 连接 协议 称 为 CONP 
(Connection-oriented Network Protocol， 面 向 连接 网 络 协议 ) ， 类 似 
于 Netware 网 络 中 的 IPX 协 议 。 在 整个 ISO 网 络 中 ， 提 供 CLNS 服 务 的 
有 : CLNP、IS-IS 和 ES-IS， 这 三 个 分 别 实 现 不 同 的 功能 。 在 此 对 这 三 


个 协议 进行 简单 介绍 。 


1.CLNP 


CLNP 是 ISO 网 络 层 数据 报 协议 ， 对 于 传输 层 来 说 ， 它 提供 了 与 
TC/IP 网 络 中 的 IP 协 议 类 似 的 基础 功能 ， 因 此 ，CLNP 叉 称 ISO-IP。 与 
IP 协 议 一 样 ，CLNP 也 是 一 个 无 连接 的 网 络 层 协议 ， 提 供 无 连接 的 网 络 
层 服务 。 我 们 都 知道 ， 卫 是 TCP/AP 协 议 栈 中 唯一 的 网 络 层 协议 ， 高 层 
的 协议 和 数据 全 都 封装 在 了 数据 包 中 ， 然 后 再 传输 到 数据 链 路 层 ， 重 
新 封装 在 帧 中 进行 传输 。 而 在 ISO 网 络 环境 中 ， 前 面 说 的 CLNP、IS- 
IS、ES-IS 都 是 独立 的 网 络 层 协议 ， 都 直接 被 封装 到 数据 链 路 层 的 帧 中 
进行 传输 。CLNP 使 用 NSAP 地 址 〈P 协 议 使 用 的 是 耻 地 址 ) 和 NET 

(网 络 实体 标识 ) 来 识别 网 络 设备 。 


2.1S-1S 


IS-IS 最 早 仅 在 使 用 CLNP 协 议 的 ISO 网 络 中 实现 各 路 由 器 间 路 由 信 
妃 区 换 的 协议 ， 也 就 是 ISO 网 络 的 动态 路 由 协议 。 但 是 现在 我 们 通常 
说 IS-IS 不 仅 适 用 于 ISO 网 络 ， 同 样 适用 于 TCP/IP 网 络 ， 因 为 现在 的 IS- 
IS 是 经 过 标准 化 并 且 得 到 扩展 后 的 版 本 。 


IS-IS 协 议 最 早 是 在 1980 年 后 期 由 DEC 公 司 开 发 的 ， 后 来 由 ISO 以 
标准 的 形式 发 布 在 ISO/IEC 10589 标 准 中 。 当 时 它 仅 支持 CLNS 网 络 环 
境 ， 而 不 文 持 IP 网 络 环境 中 的 路 由 信息 交换 。 再 后 来 ，IETF 在 RFC 
1195 中 对 IS-IS 进 行 了 修改 和 扩展 ， 修 改 和 扩展 后 的 IS-IS 称 为 集成 IS-IS 


(Integrated IS-IS) 或 双重 IS-IS (Dual IS-IS) 。 集 成 IS-IS 的 制定 是 为 
了 使 其 能 够 同时 应 用 在 TCP/PP 网 络 和 OSIRM 体 系 结构 网 络 中 ， 使 其 能 
够 为 IP 网 络 提 供 动态 的 路 由 信息 交换 。 随 后 由 IFTF 扩 展 ， 使 得 IS-1S 文 
持 将 来 必 将 成 为 主流 的 IPv6 协 议 。 现 在 网 络 设备 中 的 IS-IS 一 般 都 同时 
支持 CNLP、IPv4 和 IPV6 网 络 协 议 。 


集成 IS-IS 是 一 个 能 够 同时 处 理 多 个 网 络 层 协议 (例如 IP 和 
CLNP) 的 路 由 选择 协议 。 相 反 ，OSPF 只 支持 PP 一 种 网 络 层 协议 ， 即 
OSPF 仅 支持 IP 路 由 ， 专 为 TCP/IP 网 络 设计 。 和 集成 1S-IS 可 以 支持 纯 
CLNP 网 络 或 纯 IP 网 络 ， 或 者 同时 支持 CLNP 和 IP 两 种 网 络 环境 ， 并 为 
其 提供 路 由 功能 。 集 成 IS-IS 协 议 经 过 多 年 的 发 展 ， 已 经 成 为 一 个 可 扩 
展 的 、 功 能 强大 、 易 用 的 IGP 路 由 选择 协议 ， 并 且 在 运营 商 网 络 中 得 
到 了 更 多 的 应 用 和 部 署 ， 主 要 用 来 实现 域内 (也 就 是 一 个 自治 系统 
内 ) 的 IP 路 由 选择 。 


3.ES-IS 


ES-IS 的 英文 全 称 为 End System to Intermediate System Routing 
Exchange Protocol， 翻 译 成 中 文 就 是 终端 系统 到 中 间 系 统 的 路 由 交换 
协议 ， 是 由 ISO 开发 ， 用 来 允许 终端 系统 和 中 间 系 统 进行 配置 和 路 由 

言 奶 的 交换 ， 以 推动 TSO 网 络 环境 下 网 络 层 的 路 由 选择 和 中 继 功能 的 
操作 。 终 端 系统 指 用 户 设备 ， 中 间 系 统 指 路 由 器 。 它 在 CLNP 网 络 


中 ， 就 像 耻 网 络 中 的 ARP、ICMP 一 样 ， 为 终端 系统 与 路 由 器 间 提 供 路 
由 信息 交换 功能 。 


9.3.2 IS-IS 路 由 协议 基本 术语 

要 正确 理解 1S-IS 路 由 协议 工作 原理 ， 首 先 要 理解 以 下 这 些 基本 专 
业 术语 。 

(1) IS (Intermediate System， 中 间 系 统 ) 


忠 古 TCP/IP 网 络 中 的 路 由 器 。 它 是 1S-IS 协 议 中 生成 路 由 和 传播 路 
由 信息 的 基本 单元 。 在 本 草 下 文中 IS 和 路 由 右 具 有 相同 的 舍 义 。 


(2) ES (End System， 终 端 系统 ) 


相当 于 TCP/IP 网 络 中 的 主机 系统 。ES 不 参与 1S-IS 路 由 协议 的 处 
理 ， 在 ISO 网 络 中 使 用 专门 的 ES-IS 协 议定 义 终端 系统 与 中 间 系 统 间 的 


通信 。 
(3) RD (Routing Domain， 路 由 域 ) 
指 多 个 使 用 IS-IS 协 议 的 路 由 器 所 组 成 的 范围 。 
(4) Area (区 域 ) 


指 IS-IS 路 由 域 的 细 分 单元 ，IS-IS 像 OSPF 一 样 允 许 将 整个 路 由 域 


分 为 多 个 区 域 。 


经 验 之 谈 ”其 实在 整个 动态 路 由 中 ， 有 三 个 术语 最 容易 区 分 ， 那 
就 是 自治 系统 (AS) 、 路 由 域 (Route Domain，RD) 和 区 域 
(Area) 。 总 体 而 言 ， 传 统 意义 的 AS 为 一 组 运行 同一 路 由 协议 ， 并 被 
同一 组 织 机 构 管 理 的 路 由 器 。 现 在 AS 的 概念 扩展 了 ， 可 以 是 运行 多 个 
不 同 路 由 协议 ， 但 由 同一 组 织 机 构 管理 的 一 组 路 由 侣 。 路 由 域 与 传统 
的 AS 定 义 类 似 ， 也 是 指 运行 同一 种 路 由 协议 ， 并 被 同一 组 织 机 构 管 理 
的 一 组 路 由 器 。 区 域 是 为 了 降低 路 由 器 的 负载 而 划分 的 路 由 域内 的 子 
域 。 子 域内 的 路 由 器 维护 子 域内 部 具体 路 由 信息 和 到 达 路 由 域内 其 他 
子 域 的 路 由 信息 。 如 果 从 所 包含 的 范围 来 比较 的 话 可 以 得 出 如 下 不 等 
式 关系 : AS>RD>Area。 


当 每 个 路 由 协议 配置 不 同 的 AS 时 ，AS 与 RD 是 相等 的 ， 当 多 个 不 
同 路 由 协议 放 进 一 个 AS 中 ， 则 AS 大 于 RD。 当 一 个 路 由 进程 只 创建 一 
个 区 域 时 ，RD 与 Area 相 等 ， 但 通常 是 一 个 路 由 域 中 要 划分 多 个 区 域 ， 
所 以 通常 是 RD 大 于 Area。 它 们 之 间 可 能 的 关系 可 用 图 9-27 来 表示 。 
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9-27 AS、RD 与 Area 之 间 的 关系 


(5) LSDB (Link State DataBase， 链 路 状态 数据 库 ) 


网 络 内 所 有 链 路 的 状态 构成 了 LSDB， 在 每 一 个 IS 中 都 至 少 有 一 个 
LSDB。1IS 使 用 SPF 算 法 (与 OSPF 协 议 使 用 的 算法 一 样 ) ， 利 用 LSDB 
来 生成 自己 的 路 由 。 


(6) LSPDU (Link State Protocol Data Unit， 链 路 状态 协议 数据 
单元 ) 


简称 LSP。 在 IS-IS 中 ， 每 一 个 IS 都 会 生成 LSP， 此 LSP 包 含 了 本 IS 
的 所 有 链 路 状态 信息 。 在 IS-IS 路 由 协议 中 使 用 LSP 来 描述 本 路 由 器 的 


链 路 状态 信息 。 通 过 LSP 的 泛 洪 ， 最 终 使 整个 区 域内 的 所 有 中 了 间 系 统 
拥有 相同 的 LSDB。 功 能 上 类 似 于 OSPF 中 的 LSA， 但 是 LSA 并 不 是 一 
种 单独 的 报 文 ， 是 封装 在 OSPF 的 协议 中 的 。 


(7) DIS (Designated IS， 指 定 IS) 


指定 IS 是 在 广播 或 多 路 访问 式 网 络 上 选举 的 。 在 IS-IS 广 播 网 络 类 
型 中 ， 需 要 选举 一 个 指定 的 中 间 系 统 ， 周 期 性 的 向 其 他 路 由 器 进行 
LSDB 数 据 库 的 泛 洪 ， 功 能 类 似 于 OSPF 中 的 DR (Designated 
Router) 。 但 是 在 OSPF 中 还 有 备份 BDR (Backup Designated Router) 
的 概念 ，IS-IS 中 没有 备份 的 DIS 的 概念 。 

(8) NSAP (Network Service Access Point， 网 络 服务 接 入 点 ) 

即 ISO 网 络 中 的 网 络 层 地 址 ， 用 来 标识 一 个 抽象 的 网 络 服务 访问 
点 ， 描 述 OSI 模 型 的 网 络 地 址 结构 。 整 个 NSAP 地 址 由 两 大 部 分 组 成 : 
IDP (Inter-Domain Portion) 域 间 部 分 和 DSP (Domain Service 


Portion) 域内 服务 部 分 。IDP 类 似 于 TCP/IP 地 址 中 的 主 网 络 ID; DSP 类 
似 于 TCP/IP 地 址 中 子 网 络 ID、 主 机 ID 和 端口 号 。 


(9) PDU (Packet Data Unit， 报 文 数据 单元 ) 


链 路 数据 层 传递 的 数据 报 文 格式 。IS-IS 路 由 协议 中 又 可 分 为 Hello 
PDU、LS PDU、CSN PDU、PSN PDU。 与 OSPF 协 议 对 比 ，OSPF 协 议 


承载 在 IP 协 议 之 上 ， 所 以 PDU 功 能 上 有 点 类 似 于 IP 报 文 ， 而 IS-IS 协 议 
是 直接 承载 在 数据 链 路 层 上 ， 不 需要 经 过 三 层 协议 封装 。 


(10) Sys ID (System ID， 系 统 ID) 


在 IS-IS 路 由 协议 中 使 用 Sys ID 唯一 标识 一 人 台中 间 系 统 ， 必 须 保 证 
在 整个 IS-IS 路 由 域 中 System ID 的 唯一 性 。 功 能 上 类 似 于 OSPF 的 Router 
ID 。 


(11) NET (Network Entity Title， 网 络 实体 标题 ) 


特殊 的 NSAP 地 址 ， 其 中 的 N-Selector 部 分 为 全 0， 专 门 为 IS-IS 设 
计 。 目 前 Cisco IOS 和 H3C 都 支持 一 台 路 由 器 上 最 多 配置 3 个 NET， 方 便 
进行 网 络 的 迁移 。 有 关 NSAP 地 址 的 具体 格式 将 在 本 章 后 面 介绍 。 


(12) IIH (IS to1IS Hello PDU，1IS 到 IS 间 的 Hello PDU) 


在 IS-IS 路 由 协议 中 使 用 IIH 报 文 进行 邻居 的 发 现 、 建 立 和 维护 。 
IS-IS 协 议 规定 的 HelloO 有 三 种 : ESH (ES to IS Hello) 、ISH (IS to ES 
Hello) 和 IIH (IS to IS Hello) 。 但 是 纯 卫 的 环境 中 只 使 用 HH 一 种 
Hello PDU。 功 能 上 类 似 于 OSPF 中 的 Hello 报 文 。 


(13) PSNP (Partial Sequence Number PDU， 部 分 序列 号 数据 


S 


在 点 到 点 的 网 络 类 型 中 用 于 确认 链 路 数据 信息 ， 类 似 于 OSPF 协 议 
中 的 LSAck 报 文 ， 在 广播 网 络 类 型 中 用 于 请 求 和 确认 链 路 数据 信息 ， 
类 似 于 OSPF 协 议 中 的 LS Request 报 文 和 LSAck 报 文 。 


(14) CSNP (Complete Sequence Number PDU， 完 全 序列 号 数据 


S 


在 IS-IS 路 由 协议 中 用 于 发 布 完 整 的 链 路 数据 信息 。 在 广播 网 络 类 
型 中 DIS 路 由 器 生成 的 伪 市 点 周期 性 地 发 送 CSNP 报 文 给 其 他 路 由 絮 进 
行 数据 库 的 同步 ， 功 能 上 类 似 于 OSPF 协 议 中 的 DD 报 文 。 


9.3.3 IS-IS 路 由 及 路 由 硕 类 型 


通过 前 面 的 介绍 ， 我 们 已 经 知道 ，IS-IS 最 初 就 是 ISO 网 络 的 网 络 
层 路 由 协议 ， 所 以 它 的 路 由 选择 功能 就 与 1P 网 络 中 的 路 由 功能 实现 上 
有 些 不 一 样 。 下 面 先 来 简单 了 解 一 下 。 


1.ISO 网 络 中 的 路 由 选择 级 别 


在 ISO 网 络 中 路 由 中 包括 了 四 个 级 别 : Level-0、Level-1、Level-2 
和 Level-3。 


(1) Level-0 路 由 


Level-0 路 由 是 指 在 ES 与 IS 之 间 的 路 由 ， 通 过 使 用 ES-IS 协 议 进行 

路 由 信息 的 交换 。 在 ES-IS 协 议 中 ，ES 通 过 侦 听 IS 发 送 的 IIH 报 文 (IS 

到 IS 的 Hello 报 文 ) 来 获知 IS 的 存在 。 当 ES 要 向 其 他 ES 发 送 ESH 报 文 
(ES 的 Hello 报 文 ) 时， 将 同时 把 报 文 发 送 到 IS。 同 样 ，IS 也 侦 听 ES 发 
送 的 ESH 报 文 以 获知 ES 的 存在 ， 当 有 数据 包 要 发 送 某 个 ES 时 ，IS 便 根 
据 通 过 ESH 获 取 到 的 信息 发 送 个 特定 的 ES。 这 个 过 程 吏 称 为 Level-0 路 


(2) Level-1 路 由 


Level-1 路 由 是 指 在 同一 区 域内 IS 之 间 的 路 由 。IS-IS 中 的 区 域 是 指 
在 CLNP 地 址 中 拥有 相同 区 域 前 级 的 一 组 ES 和 IS。 同 一 个 区 域 中 的 IS 之 
间 通 过 交换 路 由 信息 后 ， 便 得 知 了 本 区 域内 的 所 有 路 径 。 当 IS 收 到 一 
个 到 目标 地 址 是 本 区 域内 地 址 的 数据 包 后 ， 通 过 查看 数据 包 的 目的 地 
址 即 可 将 数据 包 发 往 正确 的 链 路 或 目的 地 。 


(3) Level-2 路 由 


Level-2 路 由 是 指 在 不 同 区 域 中 的 IS 则 的 路 由 ， 是 区 域 间 路 由 。 当 
一 个 IS 收 到 的 一 个 目的 地 址 不 是 本 区 域 CLNP 地 址 的 数据 包 时 ， 便 将 其 
转发 到 正确 的 目的 地 ， 或 者 将 数据 包 中 继 到 其 他 区 域 ， 以 便 由 其 他 区 
域 中 的 IS 转 发 到 正确 的 目的 地 。 


(4) Level-3 路 由 


Level-3 路 由 是 指 不 同 IS-IS 域 间 的 路 由 。Level-3 路 由 类 似 与 卫 网 络 
中 的 BGP (Border Gateway Protocol， 边 界 网 关 协 议 ) ， 其 目的 是 在 不 
同 的 路 由 域 或 自治 系统 间 交 换 路 由 信息 ， 并 将 去 往 其 他 AS 的 数据 包 转 
发 到 正确 的 As， 以便 到 达 最 终 目 的 地 。 这 些 AS 之 间 可 能 拥有 不 同 的 
路 由 拓扑 ， 所 以 不 能 直接 进行 路 由 信息 的 交换 。 通 常 Level-3 路 由 是 由 
IRDP (Inter-Domain Routing Protocol， 域 间 路 由 选择 协议 ) 来 完成 
的 ，IRDP 的 功能 类 似 于 IP 路 由 中 的 BGP 路 由 协议 。 


IS-IS 所 完成 的 路 由 功能 就 是 以 上 的 Level-1 和 Level-2 路 由 功能 (分 
别 简称 为 L1 和 L2 级 路 由 ) ， 也 就 是 说 ，IS-IS 就 是 用 来 在 同一 个 路 由 域 
内 进行 区 域内 和 区 域 间 的 路 由 选择 ， 是 整个 ISO 网 络 中 路 由 选择 功能 
的 一 部 分 。Level-1 区 域内 的 路 由 是 通过 得 看 地 址 中 的 系统 ID 后 ， 然 后 
选择 最 短 的 路 径 来 完成 的 。Level-2 区 域 间 的 路 由 通过 查看 数据 包 的 目 
标 区 域 地 址 〈 非 本 区 域 的 区 域 地 址 ) 选择 一 条 最 短 的 路 径 来 路 由 数据 
包 。 


2.IS-IS 路 由 器 类 型 


由 于 IS-IS 只 负责 L1 和 L2 级 的 路 由 器 路 由 ， 这 样 一 来 ， 根 据 路 由 需 
所 处 的 网 络 位 置 不 同 ， 又 可 以 把 这 些 IS-IS 路 由 需 分 为 三 类 : LI1 路 由 需 
(Level-1) 、L2 路 由 器 (Level-2) 和 L1/L2 (Level-1-2) 路 由 器 。 无 
论 是 L1、L2， 还 是 L1/L2 路 由 侣 ， 都 采用 相同 的 SPF 算 法 ， 分 别 生 成 各 
自 进 行 数据 包 转 发 时 所 需 的 最 短路 人 径 树 (Shortest Path Tree，SPT) 。 
下 面 分 别 予 以 介绍 。 


(1) L1 路 由 器 


L1 路 由 器 束 是 IS-IS 区 域内 的 路 由 右 ， 位 于 一 个 区 域内 部 ， 类 似 于 
OSPF 网 络 中 的 区 域内 部 路 由 器 (IR) 。L1 路 由 器 只 与 属于 同一 区 域 的 
L1 和 L1/L2 路 由 器 有 直接 连接 关系 (不 能 与 L2 路 由 器 有 直接 连接 关 
系 ) 。L1 路 由 器 与 它们 交换 路 由 信息 ， 并 维护 和 管理 本 区 域内 部 的 一 


个 L1LSDB。L1 LSDB 包 含 本 区 域 的 路 由 信息 ， 到 区 域外 的 报 文 需 转 
发 给 最 近 的 LIL2 路 由 闫 。L1 路 由 器 只 能 转发 区 域内 的 数据 包 ， 或 者 
将 到 达 其 他 区 域 的 数据 包 转 发 到 距离 它 最 近 ， 且 在 同一 区 域 的 LIL2 路 


由 器 。 
(2) L2 路 由 器 


L2 路 由 器 是 指 位 于 两 个 IS-IS 区 域 间 的 路 由 器 (一 个 或 多 个 L2 路 由 
器 构成 骨干 区 域 ) ， 用 于 连接 不 同 非 骨 干 区 域 ， 类 似 于 OSPF 网 络 中 的 
BR (骨干 路 由 器 ) 。L2 路 由 器 只 能 与 其 他 L2、L1L2 路 由 器 直接 连接 
(无 论 是 否 在 同一 个 区 域 ) ， 并 交换 路 由 信息 。 所 有 L2 和 L1/L2 路 由 
器 连接 在 一 起 即 组 成 了 骨干 网 ， 与 同一 区 域 或 者 其 他 区 域 的 L2 和 
LI1/L2 路 由 器 形成 邻居 关系 ， 维 护 一 个 L2 的 LSDB (该 LSDB 包 含 区 域 
间 的 路 由 信息 ) ， 负 责 在 不 同 区 域 间 通信 ， 骨 干 网 必须 是 物理 连续 
的 。IS-IS 的 骨干 网 (Backbone) 指 的 不 是 一 个 特定 的 区 域 。 骨 干 网 在 
转发 业务 包 时 ，L2 路 由 器 可 以 转发 区 域内 的 数据 包 ， 也 可 以 转发 区 域 
间 的 数据 包 。 


(3) LUL2 路 由 器 


同时 属于 L1 和 L2 的 路 由 器 称 为 LUL2 路 由 器 ， 类 似 于 OSPF 网 络 中 
的 ABR (区 域 边界 路 由 器 ) 。 它 既 可 以 与 同一 区 域 的 L1 和 L1/L2 路 由 
右 形 成 L1 级 路 由 的 邻居 关系 ， 也 可 以 与 同一 区 域 ， 或 者 其 他 区 域 的 志 2 


和 L1/L2 路 由 器 形成 L2 级 路 由 的 邻居 关系 。L1 路 由 絮 必 须 通 过 L1/L2 路 
由 器 才 能 连接 至 其 他 区 域 。L1L2 路 由 絮 维 护 两 个 LSDB，L1 LSDB 用 
于 区 域内 路 由 ，L2 LSDB 用 于 区 域 间 路 由 。 


9.3.4 IS-IS 写 OSPF 区 域 及 路 由 句 邻 接 天 系 比较 


IS-IS 网 络 与 OSPF 网 络 一 样 ， 也 可 以 划分 多 个 区 域 ， 但 是 IS-IS 是 工 
作 在 数据 链 路 层 的 ， 其 报 文 是 直接 以 帧 地 格式 封装 ;而 OSPF 是 工作 在 
应 用 层 的 ， 其 报 文 需 要 由 网 络 IP 包 格式 进行 封装 。 所 以 它们 两 者 划分 
区 域 的 方法 是 不 一 样 的 。 下 面 是 这 两 者 的 主要 不 同方 面 。 


(1) IS-IS 可 以 有 多 个 骨 于 区域 


OSPF 的 设计 基于 骨干 区 域 ， 而 且 只 有 一 个 骨干 区 域 (区 域 号 固定 
为 0) ， 所 有 的 非 骨 干 区 域 (通过 ABR) 必须 直接 与 骨干 相连 。 而 IS-IS 
中 可 以 有 多 个 骨干 区 域 ， 同 样 所 有 的 非 骨 干 区 域 (通过 L1/L2 路 由 器 ) 
必须 直接 与 骨干 相连 。 但 IS-IS 中 的 骨干 区 域 号 不 固定 。 上 骨干 区 域 中 全 
是 由 L2 路 由 器 构成 的 ， 无 L2 路 由 器 的 区 域 是 不 能 直接 相连 ， 中 间 必 须 
经 过 L2 路 由 器 所 在 的 骨干 区 域 相连 。 


图 9-28 所 示 为 一 个 运行 IS-IS 协 议 的 典型 网 络 结构 。 在 这 种 拓扑 结 
构 中 ，Area 1 是 骨干 区 域 (可 以 是 其 他 区 域 号 ) ， 该 区 域 中 的 所 有 路 由 
器 均 是 L2 路 由 器 。 男 外 4 个 区 域 为 非 骨干 区 域 ， 它 们 都 通过 L1/L2 路 由 
鲁 祷 L2 路 由 铝 相 连 。 


图 9-28 IS-IS 网 络 典 型 拓扑 结构 


图 9-29 是 IS-IS 网 络 的 男 外 一 种 拓扑 结构 图 ， 其 中 有 两 个 骨干 区 域 
(Area 1 和 Area 3) 。 非 骨干 区 域 中 的 L1L2 路 由 器 同时 与 两 个 骨干 区 域 
的 L2 路 由 器 连接 ， 同 时 两 个 骨干 区 域 之 间 也 彼此 连接 (可 以 把 它们 看 
成 一 个 大 的 虚拟 骨干 区 域 ) ， 共 同 构成 了 一 个 IS-IS 骨 干 网 。 所 有 L2 路 
由 絮 和 L1L2 路 由 侣 构成 了 IS-IS 的 骨干 网 ， 他 们 可 以 属于 不 同 的 区 域 ， 
但 必须 是 物理 连续 的 。 
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图 9-29 IS-IS 网 络 的 一 种 非典 型 拓扑 结构 
(2) 区 域 边界 不 同 


OSPF 的 区 域 边 界 在 ABR 路 由 器 上 ，OSPF 的 每 条 链 路 都 属于 某 个 区 
域 。 如 图 9-30 所 示 ，ABR 的 不 同 接口 连接 不 同 区 域 ， 且 属于 不 同 的 区 
域 ，ABR 不 单独 构成 一 个 区 域 。 而 IS-IS 的 区 域 边界 在 链 路 上 ， 与 OSPF 
ABR 类 似 的 LIL2 路 由 器 的 各 接口 虽然 也 是 用 来 连接 不 同 区 域 鸣 ， 但 这 
些 接口 都 仍 属于 某 个 非 骨 干 区 域 中 ， 链 路 两 端 分 属 不 同 区 域 (参见 图 9- 
28 及 图 9-29) ， 不 同 区 域 的 边界 仅 体现 在 不 同 区 域 间 连接 的 链 路 上 。 


Area 1 Area 0 Area 2 
ABR/ 骨干 
路 由 器 


ASBR/ 骨干 ASBR/ 骨干 


路 由 器 | External 路 由 器 


图 9-30 ”OSPF 中 的 区 域 划分 示例 


(3) 不 同 区 域 间 路 由 器 的 邻接 关系 不 同 


在 前 面 我 们 说 到 ，OSPF 网 络 中 DR Other 仅 与 DR 和 BDR 之 间 建 立 邻 
接 关 系 ，DR Other 之 间 不 交换 任何 路 由 信息 。OSPF 协 议 使 用 路 由 器 接 
口 来 划分 区 域 ， 一 台 路 由 句 可 能 同时 属于 多 个 区 域 ， 并 可 以 与 多 个 区 
域 的 路 由 器 形成 邻接 关系 ; 而 IS-IS 协 议 规定 路 由 器 整体 属于 某 个 特定 
的 区 域 ，Level-1 路 由 器 只 能 建立 Level-1 的 邻接 关系 ，Level-2 路 由 器 只 
能 建立 Level-2 的 邻接 关系 。 


另外 ， 当 IS-IS 路 由 协议 在 点 到 点 链 路 中 ， 没 有 两 次 握手 机 制 ， 即 
一 方 收 到 对 方 的 Hello， 经 过 合法 性 检查 后 ， 邻 居 就 直接 被 激活 了 。 在 
广播 链 路 中 ， 需 要 进行 两 次 握手 验证 ， 邻 居 才 可 以 被 激活 。 而 OSPF 协 


议 中 无 论 在 什么 链 路 中 均 需 要 两 次 握手 才能 建立 邻居 关系 ， 可 靠 性 更 
好 。 两 台 运行 1S-IS 的 路 由 右 在 交互 协议 报 文 实现 路 由 功能 之 前 也 必须 
首先 建立 邻接 关系 。 在 IS-IS 路 由 协议 中 ， 只 有 同一 层次 的 相 邻 路 由 恬 
才 可 能 成 为 邻接 体 。 建 立 邻 接 关 系 的 规则 如 下 : 


口 同 一 区 域 的 L1 路 由 器 和 L1/L2 路 由 器 可 以 建立 L1 级 邻接 ; 


口 同 一 区 域 的 L1 路 由 器 和 L2 路 由 器 不 能 建立 任何 邻接 ; 


口 同一 区 域 的 LUL2 路 由 器 可 以 与 LIL2 路 由 器 建立 L1 级 邻接 和 L2 
级 邻接 ; 


口 同一 区 域 的 L2 路 由 器 可 以 与 LWL2 路 由 器 建立 L2 级 邻接 ; 


口 相 邻 区 域 的 LLL2 路 由 器 与 LLL2 路 由 器 只 能 建立 L2 级 邻接 ; 


口 相 邻 区 域 的 L2 路 由 器 与 LUL2 路 由 器 只 能 建立 L2 级 邻接 。 


图 9-31 所 示 是 一 个 IS-IS 网 络 中 各 级 路 由 器 之 间 建 立 的 邻接 关系 示 
例 ， 注 意 不 带 箭 头 的 连 线 是 物理 连接 ， 带 双 箭 头 的 才 是 形成 的 邻接 关 
系 。 从 图 中 可 以 看 出 ， 只 有 区 域 1 中 的 Level-1-2 路 由 器 与 相同 区 域 1 中 
的 Lervel-1-2 路 由 器 之 间 建 立 了 Level-1 邻 接 和 Level-2 邻 接 ， 其 他 路 由 器 
之 间 都 只 建立 了 一 种 邻接 关系 。 建 立 的 原则 就 是 以 上 所 介绍 的 。 


图 9-31 IS-IS 路 由 器 邻接 关系 示例 


9.3.5 ”IS-IS PDU 报 头 格式 


IS-IS 路 由 协议 和 其 他 路 由 协议 不 同 ， 它 直接 运行 在 数据 链 路 层 之 
上 。 对 等 路 由 器 间 是 通过 传递 PDU (Protocol Data Unit， 协 议 数据 单 
元 ) 来 传递 链 路 信息 ， 完 成 链 路 数据 库 同 步 的 。IS-IS 网 络 中 使 用 的 
PDU 主 要 有 : IIH (IS-IS Hello, IS-IS Hello 包 ) 、LSP (Link-State 
Packet， 链 路 状态 包 ) 和 SNP (Sequence Number Packet， 序 列 号 包 ) 
这 三 种 。 每 一 种 都 分 Level-1 和 Level-2 两 种 。 


以 上 这 些 PDU 都 包括 一 个 报 文 头 和 可 变 长 字段 部 分 。 报 文 头 又 包 
括 通用 报头 和 专用 报头 ， 对 所 有 PDU 来 说 ， 通 用 报头 是 相同 的 ， 专 用 
报头 根据 PDU 类 型 不 同 而 不 同 。 总 体 的 IS-IS PDU 结 构 如 图 9-32 所 示 。 


9-32 ”IS-IS PDU 基 本 结构 


IS-IS PDU 通 用 报头 格式 如 图 9-33 所 示 。 


9-33 ”IS-IS PDU 通 用 报头 格式 


IS-IS PDU 通 用 报头 格式 中 各 字段 说 明 如 下 : 


ey 


口 Intradomain routing protocol discriminator: 域内 路 由 选择 协议 鉴 


别 符 ， 占 1 字 节 ， 用 于 标识 网 络 层 PDU 的 类 型 ， 回 定 为 0x83。 


口 Length indicator: 长 度 标识 符 ， 占 1 学 廊 ， 用 于 标识 报头 部 分 
(包括 通用 报头 和 专用 报头 两 部 分 ) 长 度 ， 以 字 市 为 单位 。 


品 Version/Protocol ID extension: 版 本 /协议 ID 扩 展 ， 占 1 字 节 ， 当 
前 值 固 定 为 0x01。 


DID length: ID 长 度 ， 占 1 他 方 ， 用 于 标识 NSAP 和 NET 地 址 长 
度 O 〇 


DPDU type: PDU 类 型 ， 占 5 位 ， 用 于 标识 IS-IS PDU 数 据 包 的 类 
型 。 值 为 15 表 示 L1LAN IIH; 值 为 16 表 示 L2 LAN IIH; 值 为 18 表 示 L1 
LSP; 值 为 20 表 示 L2 LSP; 值 为 24 表 示 L1 CSNP; 值 为 25 表 示 L2 
CSNP; 值 为 26 表 示 L1 PSNP; 值 为 27 表 示 L2 CSNP 。 


口 Version: 版 本 ， 占 1 字 节 ， 当 前 值 为 0x01。 
口 Reserved: 保留 位 ， 占 1 字 节 ， 当 前 值 固 定 为 0。 


口 Maximum Area Addresses: 最 多 区 域 地 址 ， 占 1 字 节 ， 标 识 文 持 
的 最 大 区 域 数 。 


9.3.6 ”IIH PDU 包 格式 


IS-IS Hello 数 据 包 用 来 建立 和 维持 IS-IS 路 由 器 之 间 的 邻接 关系 。 
IIH 数 据 包 包 括 IS-IS PDU 通 用 报头 、IH 专 用 报头 和 可 变 字段 三 部 分 。 
在 IIH 专 用 报头 部 分 包括 了 发 送 者 的 系统 ID、 分 配 的 区 域 地 址 和 发 送 路 
由 器 已 知 的 链 路 上 邻居 标识 。 另 外 ，IIH 有 以 下 三 种 类 型 : 


口 Level-1 LAN IS-IS Hello PDU (类 型 号 为 15) : 广播 网 中 L1 路 由 
器 发 送 的 IIH。 


口 Level-2 LAN IS-IS Hello PDU (类 型 号 为 16) : 广播 网 中 L2 路 由 
器 发 送 的 IIH。 


口 点 到 点 IS-IS Hello PDU (类 型 号 为 17) : 在 点 对 点 网 络 上 路 由 器 
发 送 的 IIH 。 


前 面 两 种 统称 为 广播 LAN IIH， 后 面 一 种 称 为 P2P IIH。 这 些 不 同 
类 型 的 IIH 的 PDU 包 格式 不 完全 一 样 ， 图 9-34 所 示 的 是 广播 网 中 L1 和 L2 
路 由 句 发 送 的 IIH PDU 包 的 格式 ， 而 图 9-35 所 示 的 是 点 对 点 网 络 中 路 由 
娇 发 送 的 IH PDU 包 的 格式 。 下 面 介绍 这 些 IH PDU 包 专用 报头 部 分 各 


个 字段 的 侣 义 。 


a 


Length indicator 
Verslon/Protocol ID extension 
通用 报 ID length 


Intradomain routing protocol discriminator 


PDU type 


ja js ja pr pe 


hn 长 
; 
psn 


图 9-34 广播 网 中 L1 和 L2 路 由 器 发 送 的 IIH PDU 包 格式 


Verslion/Protocol ID extension 
人 


专用 报 


Variable length fields 


专用 报 


图 9-35 点 对 点 网 络 IIH PDU 包 格式 
口 Reserved: 保留 字段 ， 占 6 位 。 当 前 没有 使 用 ， 始 终 为 0。 


口 Circuit type: 电路 类 型 字段 ， 占 2 位 。0x01 表 示 L1 路 由 器 ，0x10 
表示 L2 路 由 器 ，0x11 表 示 L1/2 路 由 器 。 


口 Source ID: 源 ID 字 7 段 ， 占 1 他方 ， 标 识 发 送 该 IH PDU 包 的 源 路 
由 器 SysID (系统 ID) 。 


口 Holding time: 保持 时 间 ， 占 2 字 节 ， 用 来 通知 它 的 邻居 路 由 器 在 
认为 这 台 路 由 器 失效 之 前 应 该 等 待 的 时 间 。 如 果 在 保持 时 间 内 收 到 邻 
居 发 送 的 Hello PDU， 将 认为 邻居 依然 处 于 存活 状态 。 这 个 保持 时 间 就 
相当 于 OSPF 中 的 dead interval (死亡 间隔 ) 。 在 IS-IS 中 ， 默 认 情 况 下 保 
持 时 间 是 发 送 Hello PDU 间 隅 的 3 倍 ， 但 是 这 保持 时 间 是 通过 指定 一 个 
Hello 报 文 乘 数 (hello-multiplier) 进行 配置 的 。 例 如 ， 如 果 Hello PDU 
的 间隔 为 10s，Hello 报 文 乘 数 为 3， 那 么 保持 时 间 就 是 30s (10sx3) 。 


DPDU length: PDU 长 度 字 段 ， 占 2 个 字 市 ， 标 识 整 个 PDU 报 文 的 
长 度 ， 以 字 节 为 单位 。 


口 Priority: 优先 级 字段 ， 占 7 位 ， 标 识 本 路 由 着 在 DIS 选举 中 的 优 
先 级 。 值 越 大 ， 优 先 级 越 高 ， 路 由 器 成 为 DIS 的 可 能 性 越 大 。 


DLAN ID: 局 域 网 ID 字段 ， 占 “ID 长 度 +12 个 字 节 ， 由 路 由 器 的 系 
统 ID+1 个 字 克 的 伪 世 点 ID 组 成 ， 用 来 区 分 同一 台 DIS 上 的 不 同 LAN。 


对 比 图 9-34 和 图 9-35 可 以 看 出 ， 点 对 点 网 络 IIH PDU 与 广播 网 络 中 
的 IH PDU 包 格式 基本 一 样 ， 只 是 没有 了 广播 网 络 中 的 Priority 和 LAN 
ID 这 两 个 字段 ， 另 外 新 增 了 一 个 Local Circuit ID 字段 ， 用 来 标识 本 地 链 
路 ID。 


9.3.7 LSP PDU 包 格式 


与 OSPF 一 样 ， 运 行 IS-IS 路 由 选择 协议 的 路 由 器 也 是 通过 收集 其 他 
路 由 器 泛 洪 的 链 路 状态 信息 来 构建 自己 的 链 路 状态 数据 库 的 。 在 OSPF 
中 ，OSPF 路 由 器 通告 链 路 状态 信息 是 通过 LSA 实 现 的 。 在 IS-IS 中 ， 与 
LSA 具 有 同样 功能 的 包含 链 路 状态 信息 的 报 文 称 为 LSP。LSP 用 来 承载 
和 泛 洪 路 由 器 的 链 路 状态 信息 ， 并 且 LSP 是 路 由 器 进行 SPF 计 算 的 依 
据 ， 包 含 了 由 IS-IS 路 由 器 产生 的 描述 其 周围 环境 的 路 由 选择 信息 。LSP 
共 分 为 两 种 类 型 : 


(1) Level-1 LSP (类 型 号 为 18) 


Level-1 LSP 是 由 文 持 Level-1 的 路 由 器 产生 的 ， 会 在 Level-1 区 域 中 
泛 洪 。Level-1LSP 集 由 所 有 在 Level-1LSPDB (LSP Database，LSP 数 
据 库 ) 区 域 中 的 Level-1 路 由 器 的 产生 组 成 。 区 域 中 的 所 有 Level-1 路 由 
器 将 有 相同 的 Level-1 LSPDB 和 相同 的 区 域 网 络 连接 映射 。 


(2) Level-2 LSP (类 型 号 为 20) 


Level-2 LSP 是 由 文 持 Level-2 的 路 由 器 产生 的 ， 通 过 Level-2 子 域 泛 
洪 。Level-2 LSP 集 由 所 有 在 Level-2 LSPDB 域 中 的 Level-2 IS 的 产生 组 
成 。 所 有 Level-2 路 由 器 将 有 相同 的 Level-2 LSPDB 和 相同 的 Level-2 子 域 
连接 映射 。 


以 上 两 种 LSP PDU 具 有 相同 的 包 格 式 ， 如 图 9-36 所 示 。 下 面 是 LSP 
专用 报头 部 分 各 字段 介绍 。 


Intradomain routing protocol discriminator 


Length indicator 


Version/Protocol ID extension 


通用 报 ID length 
头 部 分 | [加 PDU type 


专用 报 
类 分 
Am lors 


Variable length fields 


图 9-36 LSP PDU 包 格式 


DPDU length: PDU 长 度 字 段 ， 占 2 字 方 ， 标 识 整 个 PDU 报 文 的 长 


闻 


口 Remaining Lifetime: 剩余 生存 时 间 字 段 ， 占 2 字 节 ， 标 识 此 LSP 
到 期 前 的 生存 时 间 ， 以 秒 为 单位 。 当 生存 时 间 为 0 时 ，LSP 将 被 从 链 路 
状态 数据 库 中 清除 。 


DLSP ID: LSP 标 识 符 字 段 ， 占 “系统 ID 长 度 +2? 个 字 节 ， 用 来 标识 
不 同 的 LSP 和 生成 LSP 的 源 路 由 器 。LSP ID 包括 SysID、 伪 节点 标识 符 
(Pseudonode ID) 和 LSP 编 号 三 个 部 分 。 


口 Sequence number: 序列 号 字段 ， 占 4 字 节 ， 标 识 每 个 LSP 包 的 序 


天 


口 Checksum: 校 验 和 字段 ， 占 2 子 方 ， 用 于 接收 剖 校 验 所 传送 LSP 
的 完整 性 和 正确 性 。 当 一 台 路 由 融 收 到 一 个 LSP， 在 将 该 LSP 放 入 到 本 
地 链 路 数据 库 和 将 其 再 泛 洪 给 其 他 邻接 路 由 器 之 前 ， 会 重新 计算 LSP 的 
校 验 和 ， 如 果 校 验 和 与 LSP 中 携带 的 校 验 和 不 一 至， 则 说 明 此 LSP 传 输 
过 程 中 已 经 被 破坏 。 


DP: 分 区 字段 ， 占 1 位 ， 表 示 区 域 划分 或 者 分 段 区 域 的 修复 位 ， 
仅 与 Level-2 LSP 有 关 。 当 P 位 被 设置 为 1 时 ， 表 明 始 发 路 由 器 支持 上 自动 
修复 区 域 的 分 段 情 况 。 


DATT (Attached) : 区 域 关联 字段 ， 占 4 人 位， 表示 产 生 此 LSP 的 路 
由 器 与 多 个 区 域 相连 。 虽 然 ATT 位 同时 在 L1 LSP 和 L2 LSP 中 进行 了 定 


义 ， 但 是 它 只 会 在 L1 LSP 中 被 置 位 ， 并 且 只 有 L1/2 路 由 器 会 设置 这 个 
字段 。 


DOL: 超载 字段 ， 占 1 位 ， 表 示 本 路 由 絮 因 内 在 不 足 而 导致 LSDB 
不 完整 。 被 设置 了 超载 位 的 LSP 不 会 在 网 络 中 进行 泛 洪 ， 并 且 当 其 他 路 
由 器 收 到 设置 了 超载 位 的 LSP 后 ， 在 计算 路 径 信息 时 不 会 考虑 此 LSP， 
因此 最 终 计 算出 来 的 到 达 目 的 地 的 路 径 将 绕 过 超载 的 路 由 器 。 设 置 超 
载 位 还 可 以 使 数据 的 传输 路 径 绕 过 某 个 特定 的 路 由 器 。 


DIS type: 路 由 器 类 型 字段 ， 占 2 位 ， 表 示 了 此 LSP 是 来 自 L1 路 由 
器 还 是 L2 路 由 器 ， 也 表示 了 收 到 此 LSP 的 路 由 器 将 把 这 个 LSP 放 到 L1 链 
路 状态 数据 库 还 是 L2 链 路 状态 数据 库 。0x01 表 示 L1，0x10 表 示 L2 。 


9.3.8 SNP PDU 包 格式 


SNP (Sequence Number PDU， 序 列 号 PDU) 包含 一 个 或 者 多 个 
LSP 的 汇总 描述 ， 用 于 确认 邻居 之 间 最 新 接收 的 LSP， 作 用 类 似 于 确认 
报 文 。 


SNP 可 分 为 CSNP (Complete Sequence Number PDU， 完 整 SNP) 
和 PSNP (Partial Sequence Number PDU， 部 分 SNP) 。CSNP 包 括 LSDB 
中 所 有 LSP 的 摘要 信息 ， 从 而 可 以 在 相 邻 路 由 器 间 保 持 LSDB 同 步 。 在 
广播 网 上 ，CSNP 由 DIS 定 期 发 送 (默认 发 送 周 期 为 10 秒 ) ; 在 点 对 点 
网 络 中 ，CSNP 只 在 第 一 次 建立 邻接 关系 时 发 送 。PSNP 仅 用 来 列举 最 
近 收 到 的 一 个 或 多 个 LSP 的 序号 ， 能 够 一 次 对 多 个 LSP 进 行 确认 。 当 
LSDB 不 同步 时 ， 也 用 PSNP 请 求 邻 居 发 送 新 的 LSP。 


CSNP PDU 包 格式 如 图 9-37 所 示 ，PSNP PDU 包 格式 如 图 9-38 所 
示 。 下 面 对 这 两 种 SNP PDU 包 中 专用 报头 部 分 的 各 字段 具体 介绍 。 


有 
% 部 分 | |RTRTRT ws | | 
2 


PDU length 


ID 长 度 +1 
ID 长 度 +2 
ID 长 度 +2 


图 9-37 CSNP PDU 包 格式 


Intradomain routing protocol discriminator 


Length indicator ] 


Werslon/Protocol ID extension 1 


ID length ] 


通用 报 
xf] [RAR se | 


| ， 


i 


s 用 报 ID 长 度 +1 
头 部 分 


Variable length fields 
图 9-38 PSNP PDU 包 格式 


DPDU length: PDU 长 度 字 段 ， 占 2 字 广 ， 标 识 整个 PDU 报 文 的 长 
度 o 


口 Source ID， 源 ID 字段 ， 占 “系统 ID 长 度 +1" 个 字 节 ， 标 识 发 送 该 


CSNP PDU 的 路 由 器 的 SysID。 


口 Start LSP ID: 起 始 LSP ID 字段 ， 占 “系统 ID 长 度 +2? 个 字 节 ， 表 
示 在 下 面 的 可 变 字 段 中 描述 的 LSP 范 围 中 的 第 一 个 LSP ID 号 。 


DEnd LSP ID: 结束 LSP ID 字段 ， 占 “系统 ID 长 度 +22? 个 字 节 ， 表 示 
在 下 面 的 可 变 字段 中 描述 的 LSP 范 围 中 的 最 后 一 个 LSP ID 号 。 


9.3.9 ”IS-IS PDU 可 变 字 段 格 式 


大 家 或 许 从 上 面 介 绍 的 各 种 PDU 包 格式 已 经 看 到 ， 除 了 报头 ( 包 
括 通用 报头 和 专用 报头 ) 部 分 ， 最 后 还 有 一 个 部 分 ， 就 是 “可 变 长 字 
段 ”(Variable length fields) 部 分 。 这 个 可 变 成 字段 部 分 就 是 各 种 PDU 
包 真 正 内 容 部 分 ， 是 整个 PDU 包 的 核心 部 分 。 因 为 这 部 分 内 容 都 是 
以 “Type-Length-Value”， 即 “类 型 -长 度 - 值 ?格式 列 出 的 ， 所 以 又 称 关 
TLV 部 分 。 


TLV 编 址 方式 由 三 大 部 分 组 成 : T (Type) ， 即 PDU 包 类 型 ， 不 同 
类 型 由 不 同 的 值 定 义 ; 工 〈Length) ， 即 Value 字段 的 长 度 ， 以 字 节 为 单 
位 ; V 《Value) ， 即 包 的 真正 内 容 ， 是 最 重要 的 部 分 。 但 在 ISO 10589 
和 RFC 1195 这 两 个 当前 IS-IS 标 准 中 ， 使 用 “code”( 代 码 ) 蔡 换 了 前 面 
所 说 的 “Type” 部 分 ， 所 以 这 种 报 文 编 址 方式 通常 又 称 CLV (Code- 
Length-Value) ， 如 图 9-39 所 示 。 


Code 


Length ] 


Value =Length 


图 9-39 可 变 长 字段 部 分 格式 
图 9-39 所 示 三 个 字段 的 说 明 如 下 : 


口 Code: 代码 字段 ， 占 1 字 节 ， 表 示 PDU 类 型 ， 不 同 的 IS-IS PDU 使 
用 不 同 的 类 型 。 


口 Length: 长 度 字段 ， 占 1 字 节 ， 表 示 Value 字 段 的 长 度 ， 最 大 值 为 
255 字 节 。 


口 Value: 值 字段 ， 长 度 是 可 变 的 ， 表 示 实 际 承载 的 PDU 内 容 ， 最 
大 为 255 字 节 。 


在 IS-IS PDU 所 使 用 的 各 种 TLV 中 ， 既 有 ISO 10589 中 定义 的 ， 也 有 
RFC 1195 中 定义 的 。ISO 中 定义 的 TLV 用 于 CLNP 网 络 环境 ， 但 是 其 中 
的 大 多 数 也 用 于 IP 网 络 环境 。RFC 中 定义 的 TLV 只 用 于 IP 环 境 。 也 就 是 
说 ， 对 于 一 个 IS-IS PDU， 后 面 既 可 以 携 市 文 持 CLNP 协 议 的 TLV， 义 可 
以 携 市 文 持 IP 协 议 的 TLV。 如 末 一 个 路 由 絮 不 能 识别 一 个 TLV， 那 么 将 


名 略 它 。 


至 于 IS-IS 的 各 种 TVL， 在 此 不 作 有 具体 介绍 ， 大 家 可 参考 相关 
料 。 


| 


9.3.10 ”IS-IS 的 两 种 地 址 格式 


IS-IS 中 包括 两 种 地 址 ， 一 是 用 来 标识 网 络 层 服务 的 NSAP 
(Network Service Access Point， 网 络 服务 访问 点 ) 地 址 ， 二 是 用 来 标 
识 设备 的 NET (Network Entity Titile， 网 络 实体 标题 ) 地 址 。 下 面 分 别 
予以 介绍 。 


1.NSAP 地 址 格式 


NSAP 地 址 用 来 标识 网 络 层 服务 ， 每 种 服务 对 应 一 个 NSAP 地 址 。 
NSAP 地 址 由 两 个 主要 部 分 组 成 ， 即 IDP (Inter-Domain Portion， 域 间 部 
分 ) 和 DSP (Domain Service Portion， 域 服务 部 分 ) ， 如 图 9-40 所 示 。 
与 卫 地 址 中 由 网 络 ID 和 主机 ID 两 部 分 组 成 类 似 ，IS-IS NSAP 地 址 中 的 
IDP 部 分 相当 于 TCP/IP 网 络 IP 地 址 中 的 主 网 络 ID 部 分 ， 而 DSP 部 分 则 相 
当 于 TCP/IP 网 络 IP 地 址 中 的 子 网 ID、 主 机 ID 和 闻 口 号 总 和 。 


可 变 长 度 


6 1 > 字 H 


IDP 部 分 DSP 部 分 


图 9-40 IS-IS NSAP 地 址 格式 


IDP 又 由 以 下 这 两 个 子 部 分 组 成 : 


口 AFI (Authority and format ID， 机 构 与 格式 ID) : 用 来 标识 地 址 
格式 和 对 应 地 址 的 分 配 机 构 ， 占 1 字 节 。AFI 等 于 49 的 地 址 是 私有 地 
址 ， 就 像 耻 地 址 中 的 局 域 网 地 址 一 样 ， 而 AFI 等 于 39 或 47 的 地 址 属于 
ISO 注册 地 址 ， 相 当 于 耳 地 址 的 公 网 地 址 。 


DIDI (InterDomain ID， 域 间 ID) : 用 来 标识 、 区 分 AFI 字 上 段 下 不 
同 的 域 ， 最 长 可 达 10 字 廊 。 


DSP 由 以 下 三 个 子 部 分 组 成 : 


DHODSP (High Order DSP，DSP 高 位 ) ， 用 来 在 一 个 域 中 分 割 多 
个 区 域 ， 相 当 于 了 P 地 址 中 的 子 网 ID 部 分 。 


口 SID (System ID， 系 统 ID) ， 占 6 字 节 ， 用 来 区 分 主机 ， 通 常 以 
MAC 地 址 进行 标识 ， 相 当 于 IP 地 址 中 的 主机 ID 部 分 。 当 IS 工 作 在 Level- 
1， 则 在 所 有 同 区 域 中 的 Level-1 路 由 天 的 系统 ID 必须 唯一 : 当 IS 工 作 在 
Level-2， 则 在 同一 个 路 由 域 中 所 有 路 由 器 的 系统 ID 必须 唯一 。 


DNSEL (Network-Selector， 网 络 选 择 器 ) ， 占 1 字 节 ， 用 来 指示 
选 定 的 服务 ， 相 当 于 TCP 协 议 中 的 端口 号 。 在 IS-IS 路 由 选择 过 程 中 ， 
没有 使 用 NSEL， 所 以 NSEL 始 终 保持 为 00。 


从 以 上 可 以 看 出 ，NSAP 地 址 中 包含 了 很 多 不 同 的 字段 ， 看 起 来 有 
些 复杂 。 但 实际 上 可 以 将 NSAP 地 址 进行 简化 ， 其 中 各 种 字段 可 以 归 类 
为 三 个 部 分 : 区域 地 址 、SysID 和 NSEL， 如 图 9-41 所 示 。 把 AFI、IDI 和 
HODSP 这 三 个 字段 合并 为 “Area Address” (区域 地 址 ) 字段 ， 并 且 规 定 
整个 NSAP 地 址 最 长 为 20 字 节 ， 由 于 SID 为 6 字 节 ，NSEL 为 1 字 节 ， 那 
么 “区 域 地 址 ”部 分 可 为 1~13 字 节 。 由 于 一 般 情 况 下 1 字 节 足够 用 于 定义 
区 域 ID， 所 以 在 大 多 数 的 IS-IS 实 现 中 NSAP 地 址 最 小 长 度 为 8 字 节 。 对 
于 IP 应 用 程序 而 言 ， 在 NSAP 地 址 中 ，1 字 节 定义 AFI， 最 少 2 字 节 定 义 
实际 的 区 域 信息 (IDI) ，6 字 市 定义 SID，1 字 节 定义 NSEL， 所 以 此 种 


情况 下 的 NSAP 地 址 最 少 为 10 字 节 。 


Area Address 


< 一 一 1 字 节 | 
HD 


变 长 度 6 字 - 


> 


图 9-41 简化 的 NSAP 地 址 格式 
2.NET 地 址 格式 


在 IS-IS 路 由 选择 过 程 中 ， 没 有 使 用 NSAP 地 址 中 的 NSEL 部 分 ， 所 
以 NSEL 始 终 保持 为 00。 当 NSEL 为 00 时 ， 我 们 就 称 这 个 NSAP 地 址 为 
NET 地 址 。NET 地 址 用 来 标识 网 络 层 实体 或 过 程 ， 而 不 是 服务 。 


NET 地 址 用 来 唯一 地 表示 IS-IS 路 由 选择 域 中 的 OSI 主机 ， 路 由 器 使 
用 NET 地 址 来 标识 自己 。 路 由 器 在 发 送 的 链 路 状态 数据 包 (LSP) 中 用 
NET 来 标识 自己 ， 这 类 似 于 OSPF 发 送 的 LSA 中 的 路 由 器 ID (Router 
ID) 。 通 常情 况 下 ， 一 台 路 由 器 配置 一 个 NET 即 可 ， 当 区 域 需 要 重新 
划分 时 ， 由 于 区 域 地 址 最 多 可 配置 三 个 ， 所 以 NET 最 多 也 只 能 配 三 


个 。 


整个 NET 地 址 分 成 三 个 部 分 : 区域 地 址 (Area Address) 、 系 统 ID 


(System ID) 和 NSEL (网 络 选择 器 ) 。 


如 果 一 NSAP 地 址 为 49.0001.aaaa.bbbb.cccc.00， 根 据 图 9-41 可 以 很 
快 得 出 ， 代 表 的 “区 域 地 址 ”为 49.0001 ( 因 AFI=49， 所 以 它 是 一 个 私有 
地 址 ) ， 系 统 ID 为 aaaa.bbbb.cccc，NESL 为 00。 如 果 另 一 个 NSAP 地 址 
为 39.0f01.0002.0000.0c00.1111.00， 则 可 以 得 出 “区 域 地 址 ”为 
39.0f01.0002 ( 因 AFI=39， 所 以 它 是 一 个 公有 地 址 ) ， 系 统 ID 为 


0000.0c00.1111，NSEL 为 00。 


J Ll 


IS-IS 与 OSPF 的 比较 


IS-IS 与 OSPF 是 最 为 流行 的 IGP 路 由 协议 ， 它 们 存在 许多 相同 或 者 


相似 之 处 ， 如 它们 都 是 链 路 状态 路 由 协议 ， 
优先 (SPF) 路 由 算法 ， 都 可 划分 区 域 等 。 
具体 的 比较 如 表 9-5 所 示 。 


个 综合 比较 。 


表 9-5 


都 使 用 了 相同 的 最 短路 径 
本 世 对 这 两 个 路 由 协议 做 一 


IS-IS 与 OSPF 的 比较 


相同 点 


IS-IS 和 OSPF 是 链 路 状态 路 由 协议 的 两 个 最 典型 的 代表 ， 


由 于 有 具有 快速 收 化 、 无 环 路 等 特点 ， 
OSPF 的 还 

IS-IS 和 OSPF 一 

为 了 控制 链 路 状态 数据 库 的 规模 和 复杂 度 ， 
角色 ， 但 在 细节 处 理 上 还 是 有 较 大 差别 的 


IS-IS 和 OSPF 都 能 很 好 地 支持 大 型 网 络 ， 
是 占 了 多 数 ， 而 IS-IS 在 近 几 年 开始 得 到 比较 多 的 应 用 
样 采用 Hello 协议 来 维护 邻居 关系 ， 


都 采用 SPF 算法 来 计算 路 由 
但 从 全 球 的 部 置 来 看 ， 采 用 


但 IS-IS 的 Hello 协议 与 OSPF 具体 实现 上 有 所 不 同 
IS-IS 和 OSPF 在 广播 网 络 上 都 选举 DR 来 担任 数据 库 同步 的 主要 


IS-IS 和 OSPF 对 路 由 开销 的 度量 Cmetric) 都 采用 了 接口 可 配置 的 cost， 能 够 比较 正确 地 反映 网 络 的 实际 情况 


IS-IS 和 OSPF 都 采用 分 层 路 由 的 概念 ， 都 有 肯 


干 区 域 ， 为 网 络 规 划 提供 了 比较 灵 


活 而 且 实 际 的 设计 方案 


不 同 点 


IS-IS 
IS- IS 可 以 支持 CLNP 和 卫 两 种 网 络 环境 

IS-IS 所 使 用 的 数据 包 被 直接 封装 到 数据 链 路 层 帆 中 
IS-IS 是 ISO CLNS 中 的 一 个 网 络 层 协议 

IS-IS 使 用 LSP 承载 所 有 的 路 由 选择 信息 

IS-IS 利用 TLV 可 以 灵活 的 对 协议 进行 扩展 

IS-IS 可 以 忽略 不 支持 的 TLV 


IS-IS PDU 可 以 承载 多 个 TLV 字段 ， 
节省 带宽 


sm 
ps 


IS-IS 仅 支 持 广 播 类 型 链 路 与 点 到 点 类 型 链 路 
IS-IS 邻接 关系 建立 过 程 简单 ， 仅 3 步 

数据 库 同步 在 建立 邻接 关系 之 后 

IS-IS 路 由 器 只 属于 一 个 区 域 ， 基 于 节点 分 配 区域 


有 一 个 报头 ， 


OSPF 

OSPF 仅 支 持 IP 网 络 环境 

OSPF 数据 包 被 封装 在 IP 报 文中 

OSPF 不 是 网 络 层 协议 ， 它 运行 在 IP 之 上 

OSPF 使 用 不 同类 型 的 LSA 承 裁 路 由 选择 信息 

OSPF 很 难 进行 扩展 

网 络 中 所 有 路 由 器 都 必须 能 够 识别 所 有 LSA 

1 类、2 类 LSA 可 以 承载 多 个 IP 前 级 ; 3 类、4 类 、 
5 类 LSA 只 能 承载 单个 IP 前 级， 如 果 需 要 发 送 多 个 IP 
前 级 信息 ， 需 要 多 个 LSA 

OSPF 可 以 支持 多 种 网 络 类 型 : 广播 、 点 到 点 、 
NBMA 、 点 到 多 点 和 按 需 电路 (Demand Circuit ) 


OSPF 需要 通过 多 种 状态 建立 邻接 关系 

数据 库 同步 在 邻接 关系 建立 之 前 

OSPF 路 由 器 可 以 属于 多 个 区 域 ， 典 型 的 
OSPF 基于 接口 分 配 区 域 


是 ABR， 


( 续 ) 


不 同 点 


IS-IS 

IS-IS 的 区 域 边界 在 链 路 上 

IS-IS 的 Level-1 区 域 ( 非 骨干 区 域 ) 为 末节 (stub) 
区 域 ， 除 非 使 用 路 由 渗透 (Route Leaking) 机制 

IS-IS 仅 在 点 到 点 链 路 上 的 扩散 是 可 靠 的 ， 在 广播 链 
路 中 通过 DIS 周期 性 的 发 送 CSNP 来 实现 可 靠 性 

IS-IS 中 没有 备份 DIS 

IS-IS 中 的 DIS 可 以 被 抢占 

DIS 以 3 倍 的 频率 发 送 Hello PDU 

默认 情况 下 ，IS-IS 的 LSP 最 大 生存 时 间 为 1200s， 
刷新 闻 隔 为 900s， 而 且 定 时 器 的 值 可 调 

默认 情况 下 ，IS-IS 的 接口 cost 值 为 10 

默认 情况 下 ，IS-IS 保持 时 间 (holding-time) 为 30s， 
而 且 在 建立 邻接 关系 时 不 需要 双方 的 保持 时 间 匹 配 

IS-IS 通过 将 Hello PDU 的 大 小 填充 至 接口 MTU 大 
小 来 检查 双方 的 MTU 是 否 匹 配 


OSPF 


OSPF 的 区 域 边界 在 路 由 器 上 

默认 情况 下 ，OSPF 非 骨 干 区 域 不 是 stub 区 域 ， 但 可 
以 配置 为 stub 区 域 

OSPF 在 所 有 链 路 上 的 扩散 都 是 可 靠 的 


OSPF 中 要 选举 BDR， 以 接替 DR 的 角色 

OSPF 中 的 DR 不 能 被 抢占 

DR 以 正常 的 频率 发 送 Hello 报 文 

OSPF 的 LSA 的 老化 时 间 为 3600s， 刷 新 间隔 为 
1800s， 而 且 是 固定 值 

默认 情况 下 ，OSPF 的 接口 cost 值 根据 带宽 进行 计算 

默认 情况 下 ，OSPF 的 保持 时 间 (dead-interval) 为 
40s， 而 且 为 了 建立 邻接 关系 ， 必 须 使 双方 的 保持 时 间 
一 致 

OSPF 通过 在 DBD 报 文 中 嵌入 接口 MTU 字段 来 检 
查 双 方 的 MTU 是 否 匹 配 


9.3.12 IS-IS 最 短路 径 计算 和 路 由 表 生 成 原理 


当 路 由 器 中 的 LSPDB 内 容 发 生 改 变 时 ， 每 个 路 由 器 都 使 用 SPF 独 立 
地 重新 计算 最 短路 径 。 这 个 算法 基于 前 面 介绍 的 Dijkstra 算 法 。SPF 的 
输出 是 一 组 参数 集合 ， 如 目的 地 址 和 下 一 跳 地 址 。 目 的 地 地 址 是 协议 
参数 ， 例 如 对 于 IP 网 络 来 说 是 一 个 地 址 前 缀 ， 对 于 CLNP 网 络 来 说 是 终 
端 系统 的 NSAP。 在 IS-IS 中 文 持 多 个 等 价 路 径 ， 此 时 到 达 相 同 目的 地 址 
就 可 能 有 不 同 的 下 一 跳 。 


SPF 计 算是 由 每 个 路 由 器 独立 完成 的 ， 这 时 就 会 存在 同时 有 到 达 同 
一 目的 地 址 的 Level-1 和 Level-2 两 种 路 径 ， 但 Level-1 路 径 优先 。 链 路 状 
态 路 由 协议 都 是 基于 近邻 关系 的 ， 每 个 路 由 器 公开 其 链 路 的 开销 和 状 
态 。 所 以 区 域 里 每 个 路 由 器 知道 区 域内 所 有 活动 的 链 路 ， 并 知道 有 关 
这 些 活 动 链 路 所 标识 路 由 器 发 起 的 信息 ， 然 后 把 该 状态 信息 传播 到 其 
他 路 由 器 。 传 播 信息 使 所 有 路 由 器 保持 为 同一 数据 库 。 每 个 路 由 器 用 
唯一 的 地 址 来 标识 ， 从 而 避免 了 循环 。 


1.IS-IS 最 短路 径 计 算 原 理 


应 SPF 算 法 在 计算 最 短路 径 时 ， 每 台 路 由 需 都 是 以 目 己 为 根 结 点 ， 
其 他 路 由 需 为 叶子 结 点 ， 根 据 网 络 拓扑 信息 生成 一 柠 最 短路 径 树 
(SPT) ， 然 后 计算 出 根 结 点 到 各 个 目的 地 的 最 短路 径 。 由 于 IS-IS 路 由 


协议 采用 分 层 的 网 络 结构 ，SPF 算 法 根据 Level-1 和 Level-2 两 个 数据 库 
分 别 独 立 计算 各 自 的 SPT 树 。 下 面 以 图 9-42 中 所 示 的 A 路 由 器 为 例 ， 介 
绍 IS-IS 路 由 的 计算 过 程 。 


图 9-42  IS-IS 最 短路 径 计 算 示 例 


A 路 由 句 根 据 本 地 链 路 数据 库 信 息 ， 以 目 己 为 根 路 由 器 ， 其 他 路 由 
需 为 叶子 结 点 ， 使 用 SPF 算 法 产生 了 图 9-42 所 示 的 SPT 最 短路 径 树 。 然 
后 根据 最 短路 径 树 上 的 附带 的 开销 值 计 算出 根 结 点 到 各 个 目的 网 段 的 
路 由 。 由 于 产生 的 SPT 树 为 单 向 ， 且 不 可 逆转 的 路 径 树 ， 可 以 从 算法 上 
保证 区 域内 无 路 由 环 路 的 发 生 。 


2.IS-IS 路 由 表 的 生成 原理 


通过 可 靠 的 扩散 算法 各 路 由 器 将 其 他 路 由 融 扩 散 来 的 拓扑 信息 收 
集 起 来 ， 组 成 一 张 一 致 、 完 整 的 拓扑 图 ， 依 靠 SPF 算 法 来 计算 出 目 己 的 


路 由 表 。IS-IS 路 由 协议 中 区 域 中 所 有 的 路 由 融 拥 有 相同 的 链 路 状态 效 
据 库 LSDB， 但 是 每 人 台 路 由 需 都 生 以 目 己 为 根 结 点 ， 其 他 路 由 大 为 叶子 
结 点 ， 生 成 了 一 棵 单 向 的 、 不 可 逆转 的 最 短路 径 树 SPT。 然 后 根据 SPT 
树 以 及 链 路 相应 的 开销 值 计算 出 各 自 的 路 由 表 。 


图 9-43 显 示 了 如 何 使 用 LSP 来 创建 一 个 网 络 地 图 。 假 设 网 络 拓 扑 结 
构 是 一 个 拼图 ， 每 个 LSP 看 成 一 个 拼图 片 。 图 中 的 所 有 路 由 如 适用 于 在 
一 个 区 域 中 的 所 有 Level-1 路 由 器 或 者 一 个 Level-2 子 域 中 的 所 有 Level-2 
路 由 屁 。 
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图 9-43 IS-IS 网 络 地 图 示例 


图 9-44 显 示 了 在 IS-IS 网 络 中 的 这 些 邻 大 路 由 絮 之 间 形 成 邻接 关系 
， 带 有 完整 更 狐 链 路 状态 数据 的 每 个 路 由 器 。 从 中 可 以 看 到 各 路 由 


i 


屁 的 链 路 状态 信息 是 完全 一 致 的 ， 包 括 了 网 络 中 各 路 由 器 的 网 络 连 接 
信息 ， 这 就 是 LSDB 同 步 的 结果 。 图 中 的 路 由 器 适用 于 在 一 个 区 域 中 的 
所 有 Level-1 路 由 器 或 者 一 个 Level-2 子 域 中 的 所 有 Level-2 路 由 器 。 
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图 9-44 LSDB 同 步 后 的 各 路 由 天 路 由 表 


9.4 BGP 


BGP (Border Gateway Protocol， 边 界 网 关 协 议 ) 是 一 个 在 包含 独 
立 路 由 策略 (也 就 是 独立 AS) 的 分 离 路 由 域 间 的 无 环 路 路 由 协议 。 很 
显然 ， 相 比 前 面 介 绍 的 RIP、OSPF 这 些 内 部 网 关 路 由 协议 来 说 ，BGP 
更 加 复杂 。 也 正如 此 ，BGP 主 要 用 于 大 型 网 络 和 ISP 运 营 商 ， 在 此 我 们 
仅 作 一 般 意义 上 的 了 解 即 可 。 


目前 最 新 的 版 本 是 BGPv4， 包 括 文 持 4 字 节 的 AS 号 和 多 协议 扩 
展 ， 以 允许 BGP 为 IP 组 播 路 由 和 多 个 三 层 协议 地 址 (包括 IPv4、 
IPv6) 、VPNv4、CLNS (Connectionless Network Service， 无 连接 网 
络 服务 ) 和 二 层 VPN (L2VPN) 承载 路 由 信息 。 


9.4.1 BGP 概 壕 


BGP 是 一 个 设计 在 组 织 网 络 间 (也 就 是 路 由 域 间 ， 或 者 说 是 路 由 
域 边界 ) 提供 无 环 路 的 域 则 路 由 协议 。 它 使 用 可 靠 传输 协议 TCP 179 
号 端口 (这 是 目的 端口 ， 本 地 端口 可 以 随意 ) 来 传输 BGP 通 信 ， 因 为 
TCP 古 一 个 面 疝 连 接 的 协议 。 


BGP 主 要 用 于 连接 一 个 本 地 网 络 到 外 部 网 络 ， 以 访问 Internet 或 者 
与 其 他 公司 网 络 。 当 用 于 连接 外 部 其 他 公司 网 络 时 ， 将 创建 一 个 对 等 


的 外 部 BGP (external BGP，eBGP) 会 话 。 虽 然 BGP 是 一 个 外 部 网 天 

(Exterior Gateway Protocol，EGP) 协议 ， 但 许多 公司 内 部 网 络 也 正 
变 得 越 来 越 复杂 ，BGP 也 可 以 用 于 在 一 个 公司 内 部 网 络 间 的 互 连 。 在 
同一 公司 内 部 的 BGP peer (可 理解 为 BGP 会 话 两 端的 路 由 器 ) 之 间 通 
过 内 部 BGP (intemal BGP，iBGP) 对 等 会 话 交 换 路 由 协议 。 


人 | 


许 


BGP 使 用 的 路 径 矢 量 (path-vector) 路 由 算法 ， 是 由 距离 矢量 

(distance-vector) 路 由 算法 和 AS 路 径 (AS-path) 环 路 检测 组 成 的 。 
通过 路 径 矢 量 算法 可 与 其 他 BGP speaking (可 理解 为 分 支 ) 连 网 设备 
在 进行 路 由 更 新 时 交换 网 络 可 达 信 息 。 网 络 可 达 信息 包括 网 络 号 、 路 

参数 属性 和 一 个 路 由 传输 到 达 目 的 地 必须 通过 的 AS 列表 。 这 个 AS 
列表 包含 在 AS 路 径 属 性 中 。BGP 通 过 拒绝 任何 包含 本 地 AS 号 的 路 由 更 
新 来 实现 无 路 由 环 路 的 ， 因 为 包含 本 地 AS 号 的 路 由 更 新 会 表示 路 由 已 
通过 这 个 AS 进行 了 传输 ， 这 样 就 形成 了 环 路 。 


从 
全 


BGP 选 择 一 条 单一 路 径 ， 默 认为 到 达 目 的 网 络 或 主机 的 最 佳 路 
径 。 这 个 最 佳 路 径 选 择 算法 是 通过 分 析 路 径 属性 来 确定 哪个 路 径 将 被 
作为 最 佳 路 径 安 闭 在 BGP 路 由 表 中 。 每 个 路 径 携 带 用 于 BGP 最 佳 路 径 
分 析 的 公认 强制 (Well-known mandatory) 、 公 认 自 由 选择 (Well- 
known discretionary) 、 可 选 传 递 (Optional transitive) 和 可 选 非 传递 


(Optional non-transitive) 属性 。 


总 体 而 言 ，BGP 路 由 协议 具有 以 下 基本 特性 : 


口 是 一 种 外 部 网 关 协 议 (Exterior Gateway Protocol，EGP) ， 与 
OSPF、RIP 等 内 部 网 关 协 议 (Interior Gateway Protocol，IGP) 不 同 ， 
其 着 眼 点 不 在 于 发 现 和 计算 路 由 ， 而 在 于 控制 路 由 的 传播 和 选择 最 佳 
路 由 。 


口 使 用 TCP 作 为 其 传输 层 协议 (端口 号 179) ， 提 高 了 协议 的 可 靠 


口 支持 CIDR (Classless Inter-Domain Routing， 无 类 别 域 间 路 
由 ) 。 


口 路 由 更 新 时 ，BGP 只 发 送 更 新 的 路 由 ， 大 大 减少 了 BGP 传 播 路 
由 所 占用 的 带宽 ， 适 用 于 在 Internet 上 传播 大 量 的 路 由 信息 。 


口 BGP 路 由 通过 携 市 AS 路 径 信息 彻底 解决 路 由 环 路 问题 。 
口 提供 了 丰富 的 路 由 党 略 ， 能 够 对 路 由 实现 灵活 的 过 滤 和 选择 。 


口 易于 扩展 ， 能 够 适应 网 络 新 的 发 展 。 


9.4.2 BGP As 


前 面 介 绍 了 OSPF、IS-IS 路 由 协议 中 的 AS (Autonomous System ， 
目 治 系统 ) 这 个 概念 ， 在 BGP 协 议 中 同样 有 AS 的 概念 。BGP 的 AS 用 于 
划分 整个 外 部 网 络 为 一 个 个 应 用 本 地 路 由 策略 的 路 由 子 域 ， 这 样 公司 
通过 BGP 可 以 简化 路 由 域 管理 和 统一 策略 配置 。 统 一 策略 配置 对 于 
BGP 有 效 处 理 到 目的 网 络 的 路 由 非常 重要 。 


在 BGP 的 每 个 路 由 子 域 中 ， 可 以 支持 多 个 不 同 的 路 由 协议 。 但 
是 ， 每 个 路 由 协议 是 独立 管理 的 ， 其 他 路 由 协议 通过 重新 发 布 
(redistribution) 功能 可 以 与 BGP 动 态 交 换 路 由 信息 。 分 隔 的 BGP AS 动 
态 通 过 eBGP 对 等 会 话 交换 路 由 信息 ; 同一 个 AS 中 的 BGP 对 端 通过 iPBGP 
对 等 会 话 交 换 路 由 信息 。 


图 9-45 举 例 说 明了 在 分 隔 AS 中 的 两 个 路 由 右 可 以 通过 BGP 协 议 进 
行 连接 。Router A 和 Router B 是 两 个 使 用 公用 AS 号 (也 就 是 这 些 AS 号 
不 是 保留 和 私 用 的 ， 可 以 应 用 于 公共 网 络 ， 类 似 于 公 网 JP 地 址 ， 的 独 
开路 由 子 域 上 的 ISP 路 由 器 。 这 两 个 路 由 器 通过 Internet 来 传输 通信 。 
Router A 和 Router B 是 通过 eBGP 对 等 会 话 进行 连接 的 。 每 个 直接 连接 
Internet 的 公共 AS 各 目 分 配 一 个 唯一 的 AS 号 ， 用 于 标识 BGP 进 程 和 
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图 9-45 带 有 两 个 AS 的 简单 BGP 拓 扑 示 例 


经 验 之 谈 这 里 要 说 明 一 点 ， 在 BGP 通 信 中 ， 对 等 路 由 器 的 AS 号 
是 不 同 的 ， 在 Internet 上 的 公用 AS 号 也 必须 是 整个 mternet 上 唯一 的 ， 
为 它 是 由 IANA (Internet Assigned Number Authority， 互 联网 数字 分 配 
机 构 ) 全 球 统 一 分 配 的 ， 就 像 公 网 了 地址 。 私 有 AS 号 就 像 局 域 网 中 私 
有 IP 地 址 一 样 ， 各 种 专用 网 络 可 以 独立 使 用 ， 不 同 专用 网 络 可 以 重复 
使 用 ， 但 不 能 在 公用 的 Internet 上 分 配 使 用 。 


1.BGP AS 号 格式 


在 2009 年 1 月 之 前 ，RFC 4271 中 定义 可 以 使 用 的 BGP AS 号 是 一 个 2 
字 世 数 ， 取 值 在 1~65 535 范 围 之 间 。 为 了 满足 日 益 提 高 的 AS 号 需求 ， 
IANA 从 2009 年 1 月 开始 在 RFC 5396 中 定义 了 4 个 字 节 的 AS 号 ， 取 值 范 
围 从 65 536 到 4 294 967 295。AS 有 以 下 两 种 表示 格式 : 


口 Asplain (无 格式 AS) : 一 个 十 进 制 记 数 法 所 表示 的 十 进 制 值 ， 
可 以 是 2 字 节 的 ， 也 可 以 是 4 字 世 的 。 如 65 526 是 一 个 2 字 贡 的 AS 号 ， 而 


234 567 是 一 个 4 字 节 的 AS 号 。 


口 Asdot (点 分 AS) : 这 种 格式 AS 号 是 一 个 点 分 记 数 法 所 表示 的 十 
进 制 值 。 如 果 是 2 字 记 的 AS 号 ， 则 直接 用 它 的 十 进 制 表示 ， 如 果 是 4 字 
广 的 AS 号 ， 则 采用 点 分 计数 法 。 例 如 65 526 是 一 个 2 字 节 的 AS 号 ， 仍 末 
用 65 526 表 示 ， 而 234 567 是 一 个 4 字 节 的 AS 号 ， 则 要 表示 为 1.169031 。 
计算 方法 是 先 把 这 个 十 进 制 转换 成 二 进 制 (结果 为 
11010001111100111) ， 然 后 每 十 六 位 (2 字 节 ) 分 成 一 段 (分 别 得 到 1 
和 1010001111100111) ， 两 段 之 间 以 小 圆 点 分 隔 ， 再 对 这 两 段 分 别 换算 
成 十 进 制 即 是 了 。 


在 一 些 品 牌 设备 中 (如 Cisco IOS 12.0 (32) S12、12.4 (24) T 和 
以 后 版 本 的 路 由 器 中 ) 4 字 节 的 AS 号 仅 以 asdot 格 式 显示 ， 如 1.10 或 者 45 
000.64000。 在 使 用 正则 表达 式 来 匹配 asdot 格 式 AS 时 ， 则 在 表达 式 中 包 
括 一 个 用 来 表示 句点 (.) 的 指定 字符 ， 通 常 是 以 反 斜 杠 (\) 表示 。 表 


9-6 显 示 了 在 仅 asdot 格 式 可 用 时 的 2 字 节 和 4 字 节 AS 号 的 配置 和 显示 格 
式 o 
表 9-6 仅 asdot 格式 可 用 时 2 字 节 和 4 字 节 AS 号 的 配置 和 显示 格式 


格式 


asdot 


2. 保 留 和 私有 的 AS 号 


在 RFC 4893 中 ，23 456 是 保留 的 AS 号 ， 它 不 能 在 用 来 配置 AS 号 。 
后 来 ， 又 在 新 的 RFC 5389 中 规定 了 新 的 保留 AS 号 ， 它 们 是 在 644 
956~64 511 之 间 的 2 字 节 AS 号 和 在 65 536~65 551 之 间 的 4 字 节 AS 号 ， 它 
们 也 不 能 用 来 配置 。 


在 64 512~65 534 之 间 的 2 字 节 AS 号 是 私有 的 ，65 535 是 保留 用 于 特 
定 用 途 的 。 私 有 AS 号 可 以 用 于 内 部 路 由 域 (相当 于 局 域 中 使 用 的 私有 
IP 地 址 一 样 ) ， 但 不 能 传输 到 达 Internet 的 通信 。BGP 不 应 当 配 置 通告 
私有 AS 号 到 外 部 网 络 。 


9.4.3“BGP 地 址 簇 模型 


BGP AFI (Address Family Identifier， 地 址 簇 标 识 符 ) 模型 是 随 多 
协议 BGP 而 引入 的 ， 设 计 用 来 模块 化 ， 且 具有 可 伸缩 性 ， 支 持 多 AFI 和 
SAFI (Subsequent Address Family Identifier， 子 序列 地 址 族 标识 符 ) 配 
置 。 网 络 的 复杂 性 日 益 提 高 ， 许 多 公司 正在 使 用 BGP 连 接 许 多 个 AS， 
如 图 9-46 所 示 。 图 中 每 一 个 独立 的 AS 可 能 运行 几 种 路 由 ， 如 MPLS 

(Multiprotocol Label Switching， 多 协议 标签 交换 ) 和 IPv6 路 由 ， 还 可 


能 需要 通过 BGP 同 时 文 持 单 播 和 组 播 路 由 。 
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图 9-46 带 有 多 个 地 址 艇 的 BGP 网 络 拓扑 示例 


多 协议 BGP 可 以 为 多 个 网 络 层 协 议和 IP 组 播 路 由 承载 路 由 信息 。 这 
个 路 由 信息 作为 BGP 附 加 属性 (多 协议 扩展 属性 ) 加 载 在 AFI 模 型 之 
中 。 每 个 地 址 簇 维护 一 个 独立 的 BGP 数 据 库 ， 人 允许 基于 每 个 地 址 簇 配 
置 BGP 策 略 。SAFI 配 置 父 AFI 的 子 集 ， 用 于 精确 BGP 策 略 配置 。 


AFI 模 型 是 因为 NLRI 格 式 的 弹性 局 限 性 而 创建 的 ， 以 NLRI 格 式 配 
置 的 路 由 郁 可 以 有 IPv4 单 播 ， 但 限制 了 组 播 特性 。 在 NLRI 格 式 中 配置 
的 网 络 有 以 下 几 方 面 的 局 限 性 : 


口 没 有 支持 AFI 和 SAFI 配 置信 息 。 许 多 新 的 BGP 功 能 (如 MPLS) 
仅 可 在 AFI 和 SAFI 配 置 模式 下 配置 ， 不 能 在 NLRI 配 置 模式 下 配置 。 


口 不 文 持 IPv6。 在 NLRI 格 式 配置 中 的 路 由 器 不 能 与 IPv6 邻 居 建 立 
巡 眉 避 


口 限制 组 播 域 间 路 由 和 非 一致 的 组 播 和 单 播 拓扑 支持 。 在 NLRI 格 
式 中 ， 并 不 是 所 有 选项 都 是 可 用 的 ， 并 且 不 文 持 VYPNv4。NLRI 格 式 配 
置 可 以 比 AFI 模 型 配置 更 复杂 。 如 果 在 基础 杂 构 中 的 路 由 天 不 文 持 组 播 
功能 ， 或 者 蛇 略 与 配置 用 于 组 播 通信 的 策略 存在 老 异 ， 则 组 播 路 由 将 
不 被 文 持 。 


在 多 协议 BGP 中 的 AFI 模 型 支持 多 个 AFI 和 SAFI， 以 及 所 有 基于 
NLRI 的 命令 和 策略 配置 ， 并 且 辣 后 与 仪 支持 NLRI 格 式 的 路 器 由 兼容 。 
配置 使 用 AFI 模 型 的 路 由 器 具有 以 下 功能 特征 : 


口 文 持 AFI、SAFI 信 息 和 配置 。 配 置 使 用 AFI 模 型 的 路 由 器 可 以 承 
载 多 个 网 络 层 协议 地 址 复 (如 IPvV4 和 IPv6) 路 由 信息 。 


口 所 有 地 址 簇 中 的 AFI 配 置 是 相似 的 ， 而 且 在 语法 格式 上 比 NLRI 格 
式 语法 更 容易 。 


口 支持 所 有 BGP 路 由 功能 和 命令 。 


口 文 持 不 同 策略 的 一 致 或 非 一 致 单 播 和 组 播 拓扑 。 


口 支持 CLNS (无 连接 网 络 服务 ) 。 


口 支持 在 仅 文 持 NLRI 格 式 《向 后 兼容 基于 AFI 的 网 络 ) 的 路 由 器 间 
相互 操作 ， 这 包括 同时 文 持 IPv4 单 播 peer 和 组 播 NLRI peer。 


口 支持 VPN 和 VRF (VPN 路 由 和 转发 ) 实例 。VRE 的 单 播 IPv4 地 址 
可 以 在 指定 的 IPv4 VRF 地 址 簇 下 配置 ， 这 种 配置 更 新 是 集成 到 BGP 
VPNv4 数 据 库 中 的 。 


在 一 个 指定 的 地 址 族 配 置 模式 下 ， 可 以 使 用 “?“” 查 显示 当前 可 以 
使 用 的 命令 。 相同 BGP 功 能 既 可 以 在 地 址 篮 配 置 模式 下 配置 ， 又 可 以 
在 路 由 融 配 置 模式 下 配置 ， 但 是 在 路 由 融 配 置 借 式 下 的 BGP 命 令 仅 适 
用 于 IPv4 单 播 地 址 前 绥 。 要 为 其 他 地 址 篮 前 缀 (如 IPv4 组 播 或 者 IPv6 单 
播 地 址 前 级 ) 使 用 BGP 命 令 和 功能 ， 必 须 进 入 对 应 地 址 艇 配置 模式 下 
进行 配置 。 


BGP 地 址 簇 配置 模式 包括 四 个 地 址 徐 : IPv4、IPv6、CLNS 和 
VPNv4。 有 些 设 备 还 支持 L2VPN 地 址 复 ， 在 L2VPN 地 址 篮 内 支持 VPLS 
SAFI。 在 IPv4 和 IPv6 地 址 簇 SAFI 内 存在 MDT (组 播 分 布 树 ) 、 隧 道 和 
VRF。 表 9-7 所 示 为 不 同 SAFI 〈 子 序列 地 址 篮 标 识 符 ) 所 对 应 的 字段 值 
及 功能 说 明 。 为 了 确保 运行 所 有 AFI 和 SAFI 配 置 的 网 络 间 兼 容 ， 建 议 在 
设备 上 使 用 多 协议 BGP 地 址 篮 模 型 配置 BGP。 


表 9-7 SAFI 类 型 及 功能 说 明 


SAFI 字段 值 


参考 文档 
1 用 于 单 播 转 发 的 NLRI RFC 2858 
( 续 ) 
SAFI 字段 值 参考 文档 
2 用 于 组 播 转发 的 NLRI RFC 2858 
3 可 同时 用 于 单 播 和 组 播 转发 的 NLRI RFC 2858 
+4 带 有 MPLS 标签 的 NLRI RFC 3107 
64 draft-nalawade-kapoor-tunnel-safi -01.txt 
65 VPLS (Virtual Private LAN Service， 虚 拟 专用 局 域 网 服务 ) 
66 draft-nalawade-idr-mdt-safi-00.txt 


128 带 有 MPLS 标签 的 VPN 地 址 RFC-ietf-13vpn-rfc2547bis-03.txt 


9.4.4 ”BGP speaker 和 peer 的 天 系 


在 配置 BGP 路 由 中 ， 我 们 见得 最 多 的 可 能 整 古 peer 这 个 词 了 ， 它 代 
表 了 什么 ? 它 与 我 们 以 前 在 其 他 路 由 协议 中 经 常见 到 的 “邻居 *?"， 以 及 
在 BGP 路 由 配置 中 经 常见 到 的 speaker 是 什么 关系 ? 这 是 学 习 BGP 路 由 
协议 的 一 个 关键 所 在 。 


1.BGP-speaking、BGP speaker 和 peer 的 关系 


在 BGP 网 络 中， 所 有 参与 BGP 进 程 的 路 由 希 都 称 为 BGP-speaking 路 
由 器 (BGP-speaking 可 以 看 成 是 BGP 会 话 的 意思 ) 。 每 个 BGP-speaking 
路 由 器 不 能 自动 发 现 其 他 BGP-speaking 设 备 ， 通 常 需要 网 络 管理 员 手 动 
配置 BGP-speaking 间 的 关联 。 对 于 活动 的 BGP-speaking 设 备 ， 称 为 peer 
设备 ， 它 与 其 他 BGP-speaking 设 备 之 间 有 一 个 活动 的 TCP 连 接 。 


BGP 设 备 之 间 的 这 种 peer 关 系 通常 是 指 邻 大 天 系 (和 RIP、OSPF 等 
网 络 中 的 邻居 设备 关系 一 样 ) ， 也 就 是 指 这 两 个 设备 之 间 没 有 通过 其 
他 路 由 器 进行 连接 。 但 在 BGP 中 ， 直 接连 接 的 BGP 路 由 帮 的 关系 不 是 
邻居 关系 ， 而 直接 用 peer (对 等 ) 关系 描述 。 


BGP speaker 是 指 本 地 BGP 路 由 器 ， 而 peer (对 等 ， 或 者 对 端 ) 是 
指 任 何其 他 BGP-speaking 网 络 设备 。 当 然 这 种 天 系 是 相对 的 ， 就 看 当前 
是 在 哪 台 路 由 侣 上 配置 了 。 也 可 以 这 么 理解 ，BGP-Speaking 路 由 句 是 


包含 了 已 与 其 他 路 由 器 之 间 建 立 了 BGP 连 接 ， 或 者 没有 与 其 他 路 由 器 
建立 BGP 连 接 的 所 有 BGP 路 由 器 的 总 称 ，BGP speaker 是 指 自己 当前 所 
在 的 BGP 路 由 器 ， 而 peer 是 指 所 有 与 其 他 路 由 器 之 间 建 立 了 TCP 连 接 的 
BGP 路 由 器 的 总 称 。 但 是 一 个 BGP 路 由 器 可 以 有 多 个 邻居 路 由 器 ， 也 
融 相 当 于 可 能 有 多 个 peer 路 由 右 。 


现 假设 有 一 个 图 9-47 所 示 的 网 络 拓扑 ， 包 含 Router A、Router B、 
Router C、Router D 和 Router E 五 个 都 运行 了 BGP 路 由 协议 的 路 由 硕 。 其 
中 Router A 与 Router B、Router E 之 间 建 立 了 TCP 连 接 ， 而 与 Router C 之 
间 还 没有 建立 TCP 连 接 ， 目 前 正在 配置 的 是 Router A。 这 时 ， 所 有 这 五 
个 路 由 器 都 是 BGP-speaking 设 备 ，Router A 是 BGP speaker，Router B 和 


Router E 对 于 Router A 来 说 是 peer 设 备 ， 但 Router C 和 Router D 只 是 BGP- 
speaking 设 备 ， 而 不 是 peer 设 备 ， 因 为 Router C 没 有 与 Router A 建 立 TCP 
连接 ， 而 Router D 不 是 直接 与 Router A 连接 的 ， 也 就 是 不 是 邻居 关系 。 
而 且 ，Router B 与 Router EE 也 不 是 peer 天 系 ， 因 为 它们 之 间 没 有 直接 连 
接 ， 尽 管 它们 都 与 Router A 有 直接 连接 。 


Router E 


Router C 


Router B BS 


图 。9-47 BGP speaker 与 peer 的 关系 示意 图 


当 在 peer 设 备 间 (也 殊 是 相互 直接 连接 的 BGP 路 由 右 之 间 ) 建立 了 
TCP 连 接 ， 每 个 BGP peer 就 会 立即 与 对 端 交 换 所 有 的 路 由 表 ， 也 就 是 完 
整 的 BGP 路 由 表 。 在 第 一 次 交换 后 ， 后 面 的 路 由 信息 交换 在 网 络 拓扑 
发 生 更 改 ， 或 者 完成 或 者 修改 了 一 个 路 由 策略 时 仅 发 送 增 量 更 新 。 在 
长 时 间 没 有 路 由 更 新 发 送 的 时 间 段 内 ， 两 BGP 路 由 咒 对 端 也 会 交换 一 

个 称 为 keepalive 〈 存 活 ) 的 特殊 消息 ， 以 告诉 对 方 自己 仍然 正常 工作 ， 
并 没有 发 生 拓 扑 更 改 。 


2. 内 部 peer 与 外 部 peer 


BGP AS 与 我 们 在 学 习 其 他 路 由 协议 中 的 AS 是 一 样 的 概念 ， 只 是 针 
对 的 路 由 协议 不 同 而 已 。 一 个 AS 就 是 一 个 由 单一 技术 管理 〈 也 就 是 它 
可 以 单独 被 管理 ) 实体 控制 的 网 络 ， 对 应 一 个 BGP 路 由 进程 。 当 BGP 


peer 踏 由 器 位 于 不 同 AS 中 上 时， 它们 之 间 互 称 对 方 为 外 部 peer， 当 它们 位 
于 同一 个 As 中 时 ， 则 称 为 内 部 peer。 通 常 ， 外 部 peer 是 邻接 并 共享 一 个 
子 网 的 ， 内 部 peer 可 以 在 同一 个 AS 中 的 任何 地 方 。 


在 图 9-48 所 示 的 示例 中 ，Router B 与 Router C 就 是 内 部 peer 关 系 ， 它 
们 同 在 AS 45000 中 ， 并 且 通 过 共享 172.16.1.0/24 这 个 子 网 相 邻 连接 。 而 
Router A 与 Router B、Router E 之 间 ，Router 了 上 与 Router D 之 间 ，Ronuter D 
与 Router C 之 间 都 是 外 部 peer 关 系 ， 因 为 它们 各 自 不 在 同一 AS 中 。 内 部 
peer 之 间 的 连接 是 通过 iBGP 协 议 进 行 的 ， 而 外 部 peer 之 间 的 连接 则 需要 
通过 eBGP 协 议 进 行 。 在 具体 的 路 由 器 BGP 协 议 配 置 时 一 定 要 注意 正确 
选择 使 用 。 


AS 48000 
: AS 40000 Router E 二 AS 50000 
: Router A 加 ; : Router D 
3 ds 
eBGP 192.168.3.3 ceBGP 3 
\ ' i 
192.168.1.2 \ | / 192.168.2.2 
ne | ta = eS 
\n eBGP eBGP 4 
:192.168.1.1\ 0 At 
[op :2 172.16.1.2 OE CY 
iBGP 
| 7 OL 172,18.2.2: | 
; AS 45000 


图 9-48 内 /外 部 peer 关 系 示 意图 


9.4.5 ”BGP peer 会 话 建立 


当 一 个 BGP 路 由 进程 与 对 端 建立 对 等 会 话 时 ， 将 按 顺序 完成 以 下 
状态 更 改 : 


1) 空间 (Idle) : 这 是 在 路 由 进程 启动 或 者 路 由 器 复位 时 ， 进 入 
路 由 进程 的 初始 状态 。 在 这 个 状态 中 ， 路 由 亏 处 于 等 竺 状态 ， 等 行 一 
个 启动 事件 (start event， 如 与 一 个 远程 peer 路 由 器 进行 对 等 会 话 配 
置 ) 的 发 生 。 当 这 个 路 由 器 接收 到 一 个 来 自 远程 peer 的 TCP 连 接 请 求 
时 ， 路 由 器 会 发 起 其 他 启动 事件 ， 但 在 发 起 一 个 TCP 连 接 到 远程 peer 
之 前 会 等 竺 一 个 计时 器 到 期 。 如 采 这 个 路 由 器 复位 ， 则 peer 路 由 器 也 
复位 ， 这 个 BGP 路 由 进程 返回 到 空 内 状态。 


2) 连接 (Connect) : BGP 路 由 进程 检测 到 一 个 peer 正 在 试图 与 本 
地 BGP speaker 建 立 一 个 TCP 会 话 。 


3) 活动 (Active) : 在 这 个 状态 下 ， 本 地 BGP speaker 的 BGP 路 由 
进程 试图 使 用 重 试 连接 计时 器 与 一 个 peer 路 由 器 建立 一 个 TCP 会 话 。 
但 当 BGP 路 由 进程 处 于 活动 状态 时 ， 这 种 来 自 远 程 peer 的 启动 事件 是 
被 忽略 的 ， 也 就 是 本 地 BGP speaker 不 会 响应 peer 的 TCP 重 试 连接 请 
求 。 如 果 路 由 进程 被 重新 配置 或 者 发 生 错误 ，BGP 路 由 进程 将 释放 系 
统 资源 ， 返 回 到 最 初 的 空间 (idle) 状态 。 


4) 打开 发 送 (OpenSent) : 在 TCP 连 接 建立 好 后 ，BGP 路 由 进程 
发 送 一 个 Open 消 息 到 远程 peer， 并 转换 进入 到 打开 发 送 (OpenSent) 
状态 。 在 这 个 状态 下 ，BGP 进 程 可 以 接收 其 他 peer 的 Open 消 息 。 如 果 
连接 失败 ，BGP 路 由 进程 转换 到 上 面 的 活动 (Active) 状态 。 


5) 打开 接收 (OpenReceive) : 在 自己 发 送 完 Open 消 息 后 ， 束 同 
时 进入 打开 接收 (OpenReceive) 状态 。 此 时 ，BGP 路 由 进程 可 从 远程 
peer 接 收 Open 消 息 ， 等 竺 一 个 来 目 远 程 peer 的 初始 keepalive 消 息 。 当 接 
收 了 一 个 keepalive 消 息 ，BGP 路 由 进程 转换 进入 到 下 面 将 要 介绍 的 建 
立 (Established) 状态 ， 如 果 接 收 了 一 个 通知 消息 ，BGP 路 由 进程 则 
转换 进入 到 最 初 的 空间 (idle) 状态 ， 如 果 发 生 错误 或 者 发 生 了 影响 
peering 会 话 的 配置 更 改 ， 则 BGP 路 由 进程 以 FSM (Finite State 
Machine， 有 限 状 态 机 制 ， 错 误 代码 发 送 一 个 通知 消息 ， 然 后 进入 到 最 
初 的 空间 (idle) 状态 。 


6) 建立 (Established) : 当 从 远程 peer 接 收 到 了 一 个 初始 
keepalive 消 息 ， 即 表明 正在 与 远程 邻居 建立 会 话 ，BGP 路 由 进程 也 开 
台 与 远程 peer 交 换 更 新 消息 。 当 接收 了 一 个 更 新 或 者 keepalive 消 息 
时 ， 连 接 保持 计时 器 (hold timer) 也 开始 计时 了 (具体 连接 保持 的 时 
间 有 多 长 是 根据 保持 计时 器 的 配置 而 定 的 ) 。 如 果 BGP 进 程 收 到 一 个 
背 误 通知 ， 则 路 由 器 将 转换 进入 到 最 初 的 空闲 (idle) 状态 。 


9.4.6 ”BGP 的 路 由 属性 


BGP 路 由 属性 是 一 组 参数 ， 对 特定 的 路 由 进行 了 进一步 的 描述 ， 
使 得 BGP 能 够 对 路 由 进行 过 滤 和 选择 。 所 有 的 BGP 路 由 属性 都 可 以 分 
为 以 下 四 类 : 


口 公认 必须 遵循 (Well-known mandatory) : 所 有 BGP 路 由 器 都 必 
须 能 够 识别 这 种 属性 ， 且 必须 存在 于 Update 〈 更 新 ) 消息 中 。 如 果 缺 
少 这 种 属性 ， 路 由 信息 就 会 出 错 。 


口 公认 可 选 (Well-known discretionary) : 所 有 BGP 路 由 器 都 可 以 
识别 ， 但 不 要 求 必须 存在 于 Update 消 息 中 ， 可 以 根据 具体 情况 来 选 


bh 


口 可 选 过 渡 (Optional transitive) : 在 AS 之 间 具 有 可 传递 性 的 属 
。BGP 路 由 器 可 以 不 文 持 此 属性 ， 但 它 仍然 会 接收 融 有 此 属性 的 路 
由 ， 并 通告 给 其 他 对 等 体 。 


主 


口 可 选 非 过 渡 (Optional non-transitive) : 如 果 BGP 路 由 器 不 支持 
此 属性 ， 该 属性 被 名 上 略 ， 且 不 会 通告 给 其 他 对 等 体 。 


表 9-8 所 示 为 BGP 路 由 的 几 种 基本 属性 与 它们 对 应 的 属性 类 别 。 


表 9-8 路 由 属性 及 对 应 的 类 别 
属 性 类 别 


ORIGIN 公认 必须 遵循 
AS_PATH 公认 必须 遵循 
NEXT_HOP 公认 必须 遵循 
LOCAL PREF 公认 可 选 
ATOMIC AGGREGATE 公认 可 选 
AGGREGATOR 可 选 过 渡 
COMMUNITY 可 选 过 渡 
MULTI_EXIT_DISC (MED) 可 选 非 过 渡 
ORIGINATOR ID 可 选 非 过 渡 
CLUSTER_LIST 可 选 非 过 渡 


下 面 介 绍 表 9-8 中 几 种 最 主要 的 BGP 路 由 属性 。 理 解 这 些 路 由 属性 
对 于 理解 BGP 路 由 工作 原理 非常 重要 。 


1. 源 (ORIGIN) 属性 


ORIGIN 属 性 定义 路 由 信息 的 来 源 ， 也 就 是 标记 一 条 路 由 是 怎么 成 
为 BGP 路 由 的 。 它 有 以 下 三 种 可 能 : 


DIGP: 优先 级 最 高 ， 说 明 路 由 产生 于 本 AS 内 。 
DEGP: 优先 级 次 之 ， 说 明 路 由 通过 EGP 学 到 。 


Dincomplete: 优先 级 最 低 ， 但 并 不 是 说 明 路 由 不 可 达 ， 而 是 表示 
路 由 的 来 源 无 法 确定 。 例 如 ， 引 入 的 其 他 路 由 协议 的 路 由 信息 。 


2.AS 路 径 (AS_PATH) 属性 


AS_PATH 属 性 按 一 定 次 序 记录 了 某 条 路 由 从 本 地 到 目的 地 址 所 要 
经 过 的 所 有 AS 号 。 当 BGP 将 一 条 路 由 通告 到 其 他 AS 时 ， 便 会 把 本 地 AS 
号 添加 到 AS_PATH 列 表 的 最 前 面 。 收 到 此 路 由 的 BGP 路 由 器 根据 
AS_PATH 属 性 就 可 以 知道 去 目的 地 址 所 要 经 过 的 AS。 离 本 地 AS 最 近 的 
相 邻 As 号 排 在 前 面 ， 其 他 AS 号 按 顺序 依次 排列 。 图 9-49 所 示 是 从 AS 
10 中 的 路 由 器 分 别 向 AS 20 和 AS 40 中 的 路 由 器 发 送 一 条 路 由 通告 时 的 
AS_PATH 属 性 (括号 中 的 值 ， 如 30，20，10) 变化 的 示例 。 


通常 情况 下 ，BGP 不 会 接受 AS_PATH 中 已 包含 本 地 AS 号 的 路 由 ， 
从 而 避免 了 形成 路 由 环 路 的 可 能 。 同 时 ，AS_PATH 属 性 也 可 用 于 路 由 
的 选择 和 过 滤 。 在 其 他 因素 相同 的 情况 下 ，BGP 会 优 移 选择 路 径 较 短 
的 路 由 。 比 如 在 图 9-49 中 ，AS 50 中 的 BGP 路 由 器 会 选择 经 过 AS 40 的 路 
径 作 为 到 目的 地 址 8.0.0.0 的 最 优 路 由 。 


D=8.0.0.0 
(20,10) 
D=8.0.0.0 
(30,20,10) 
一 


AS 30 AS 50 


图 9-49 BGP 路 由 AS_PATH 属 性 示例 


在 某 些 应 用 中 ， 可 以 使 用 路 由 策略 来 人 为 地 增加 AS 路 径 的 长 度 ， 
以 便 更 为 灵活 地 控制 BGP 路 径 的 选择 。 通 过 AS 路 径 过 滤 列 表 ， 还 可 以 
针对 AS_PATH 有 属性 中 所 包含 的 AS 号 来 对 路 由 进行 过 滤 。 


3. 下 一 跳 (NEXT_HOP) 属性 


BGP 的 下 一 跳 属性 不 一 定 是 邻居 路 由 紫 的 人 PP 地址， 它 的 取 值 为 以 下 
三 种 情况 : 


1) 当 BGP 发 言 者 把 自己 产生 的 路 由 发 给 所 有 邻居 时 ， 将 把 该 路 由 
言 轧 的 下 一 跳 属 性 设置 为 目 己 与 对 端 连接 的 接口 地 址 。 


2) 当 BGP 发 言 者 把 接收 到 的 路 由 发 送 给 eBGP 对 等 体 时 ， 将 把 该 路 
由 信息 的 下 一 跳 属 性 设置 为 本 端 与 对 端 路 由 夷 连接 的 接口 地 址 。 


在 如 图 9-50 中 ，AS 200 中 的 路 由 右 同 AS 300 中 的 路 由 絮 发 送 路 由 
时 就 把 下 一 跳 设 为 本 端 与 对 端 路 由 器 连接 的 接口 地 址 1.1.2.1。 图 中 AS 
100 中 的 路 由 器 同 AS 200 中 的 路 由 群发 送 路 由 通告 时 的 下 一 中 设置 也 是 
如 此 。 


3) 当 BGP 发 言 者 把 从 eBGP 邻 居 得 到 的 路 由 发 给 iBGP 邻 居 时 ， 并 
不 改变 该 路 由 信息 的 下 一 跳 属 性 。 如 果 配 置 了 负载 分 担 ， 路 由 被 发 给 
iBGP 邻 大 时 则 会 修改 下 一 跳 属性 。 


在 图 9-50 中 ，AS 300 中 的 路 由 絮 在 收 到 AS 200 路 由 妖 发 来 的 路 由 
通告 时 ， 再 在 内 部 路 由 器 之 间 转 发 时 ， 下 一 跳 地 址 仍 为 原来 的 1.1.2.1 。 


D=8.0.0.0 


Next hop=1.1.2.1 


图 9-50 BGP 路 由 下 一 跳 属性 示例 
4.MED (MULTI EXIT DISC) 


MED (多 出 口 度量 ) 属性 相当 于 我 们 前 面 介 绍 RIP、OSPF 协 议 时 
所 说 的 路 由 度量 值 ， 它 用 于 判断 流量 进入 AS 时 的 最 佳 路 由 ， 也 就 是 控 
制 流量 从 哪 条 路 径 进入 AS。 当 一 个 运行 BGP 的 路 由 器 通过 不 同 的 eBGP 
对 等 体 得 到 目的 地 址 相同 但 下 一 跳 不 同 的 多 条 路 由 时 ， 在 其 他 条 件 相 
同 的 情况 下 ， 将 优先 选择 MED 值 较 小 者 作为 最 佳 路 由 。 如 图 9-51 所 
示 ， 从 AS 10 到 AS 20 的 流量 将 选择 Router B 作 为 入 口 。 


D=9.0.0.0 
Next hop=2.1.1.1 
MED=0 


IBGP 
9.0.0.0 


Ronuter D 


aodiyn 


D=9.0.0.0 
Next hop=3.1.1.1 
MED=100 


Lr Router C 
3 二 .1 
AS 10 i AS 20 


MED=100 


图 9-51 BGP 路 由 器 MED 属 性 示例 


MED 属 性 仅 在 相 邻 两 个 AS 之 间 交 换 ， 收 到 此 属性 的 AS 一 方 不 会 再 
将 其 通告 给 任何 其 他 第 三 方 AS。 通 第 情况 下 ，BGP 只 比较 来 目 同 一 个 
AS 路 由 的 MED 属 性 值 。 


5. 本 地 优先 (LOCAL PREF) 属性 


LOCAL_PREF 属 性 用 于 判断 流量 离开 AS 时 的 最 佳 路 由 ， 与 上 面 介 
绍 的 MED 属 性 所 控制 的 正好 相反 。 当 BGP 的 路 由 器 通过 不 同 的 IBGP 对 
等 体 得 到 目的 地 址 相同 但 下 一 跳 不 同 的 多 条 路 由 时 ， 将 优先 选择 


LOCAL_PREF 属 性 值 较 高 的 路 由 。 如 图 9-52 所 示 ， 从 AS 20 到 AS 10 的 
流量 将 选择 Router C 作 为 出 口 。 


Local pref=100 


D=8.0.0.0 
IBGP Next hop=3.1.1.1 
Local pref=200 


Router C AS20 
Local pref=200 


图 9-52 LOCAL PREF 属 性 


LOCAL_PREF 属 性 仪 在 iBGP 对 等 体 之 间 交 换 ， 不 通告 给 其 他 AS 。 
它 表 明 BGP 路 由 妖 的 优先 级 。 


6. 团 体 (COMMUNITY) 属性 


团体 属性 用 来 简化 路 由 党 略 的 应 用 和 降低 维护 管理 的 难度 。 它 是 
一 组 有 相同 特征 的 目的 地 址 的 集合 ， 没 有 物理 上 的 边界 ， 与 其 所 在 的 


AS 无 关 。 公 认 的 团体 属性 有 : 


DINTERNET: 默认 情况 下 ， 所 有 的 路 由 都 属于 INTERNET 团 体 。 
具有 此 属性 的 路 由 可 以 被 通告 给 所 有 的 BGP 对 等 体 。 


DNO_EXPORT: 具有 此 属性 的 路 由 在 收 到 路 由 更 新 后 ， 不 能 被 发 
布 到 本 地 AS 之 外 。 如 果 使 用 了 联盟 ， 则 不 能 被 发 布 到 团体 之 外 ， 但 可 
以 发 布 给 团体 中 的 其 他 子 AS。 


DNO_ADVERTISE: 具有 此 属性 的 路 由 被 接收 后 ， 不 能 被 通告 给 
任何 其 他 的 BGP 对 等 体 。 


DNO_EXPORT_SUBCONFED: 具有 此 属性 的 路 由 被 接收 后 ， 不 
能 被 发 布 到 本 地 AS 之 外 ， 也 不 能 发 布 到 团体 中 的 其 他 子 AS。 


9.4.7 ”BGP 的 消 居 类 型 及 报 文 格式 


BGP 协 议 有 五 种 消息 类 型 : Open (建立 ) 、Update (更 新 ) 、 
Notification (通知 )y 、Keepalive (保持 活跃) 和 Route-refresh (路 由 刷 
新 ) 。 这 些 消息 有 相同 的 报 文 头 ， 其 格式 如 图 9-53 所 示 。 


16 宁 节 


图 9-53 BGP 消 息 的 报头 格式 
图 9-53 所 示 各 字段 解释 如 下 : 


口 Marker: 占 16 字 方 ， 用 于 标明 BGP 报 文 边 界 ， 固 定 值 为 所 有 位 均 
为 1， 相 当 于 一 个 报 文 的 头 部 标识 从 。 


DLength， 占 2 字 节 ， 标 识 BGP 消 息 总 长 度 (包括 报头 在 内 ) ， 以 
字 节 为 单位 。 


口 Type: 占 1 字 节 ， 标 识 BGP 消 息 的 类 型 。 其 取 值 从 1 到 5， 分 别 表 
示 Open、Update、Notification、Keepalive 和 Route-refresh 消 妃 。 其 中 ， 
前 四 种 消息 是 在 RFC 1771 中 定义 的 ， 而 Type 为 5 的 消息 是 在 RFC 2918 中 


定义 的 。 
下 面 再 具体 介绍 这 五 种 消息 报 文 格式 。 
1.O0pen 消 忆 报 文 格式 


Open (建立 ) 消息 是 TCP 连 接 建立 后 发 送 的 第 一 个 消息 ， 用 于 建 
立 BGP 对 等 体 之 间 的 连接 关系 。 其 消息 的 报 文 格式 如 图 9-54 所 示 。 


0 7 1S 31 


My autonomous system 
Hold time 


BGP identifier 


Opt Parm Len 
Optional parameters 


图 。9-54 BGP Open 消 息 报 文 格式 


图 9-54 所 示 各 字段 解释 如 下 


口 Version: 版 本 ， 占 1 字 记 ， 标 识 BGP 版 本 号 。 对 于 BGPr4 来 说 ， 


其 值 为 4。 


口 My autonomous system: 本 地 AS 字段 ， 占 2 字 节 ， 标 识 本 地 AS 
号 。 通 过 比较 两 端 鸭 AS 号 可 以 确定 是 eBGP 连 接 还 是 记 GP 连 接 。 


口 Holdtime: 保持 时 间 ， 占 2 字 节 ， 以 秒 为 单位 。 在 建立 对 等 体 关 
系 时 两 端 要 协商 Hold time， 并 保持 一 致 。 如 果 在 这 个 时 间 内 未 收 到 对 
病 发 来 的 Keepalive 消 忆 或 Update 消 息 ， 则 认为 BGP 连 授 中 汤 。 


口 BGP identifier: BGP 标 识 符 ， 占 4 字 和 下， 以 耻 地 址 的 形式 标识 


BGP 路 由 器 ID， 用 来 识别 BGP 路 由 屁 。 


口 Opt Parm Len (Optional Parameters Length) : 可 选 参数 的 长 度 ， 


占 1 字 节 ， 标 识 可 选 参数 的 总 长 度 ， 如 果 为 0 则 没有 可 选 参数 


[© 


口 Optional parameters: 可 选 参数 ， 长 度 可 变 ， 用 于 多 协议 扩展 


(Multiprotocol Extensions) 等 功能 。 
2.Update 消 居 报 文 格式 


Update (更 新 ; 消息 用 于 在 对 等 体 之 间 交 换 路 由 信息 。 它 既 可 以 
发 布 可 达 路 由 信息 ， 也 可 以 撤销 不 可 达 路 由 信息 。 其 消息 报 文 格式 如 
图 9-55 所 示 。 


Unfeasible routes length 2 Octets 
Withdrawn routes N Octets 
Total path attribute length 2 Octets 
Path attributes N Octets 


N Octets 


图 9-55 BGP Update 消息 报 文 格式 


一 条 Update 报 文 可 以 通告 一 类 具有 相同 路 径 属性 的 可 达 路 由 ， 这 
些 路 由 放 在 NLRI (Network Layer Reachable Information， 网 络 层 可 达 信 
息 ) 字段 中 ，Path Attributes 字 段 携带 了 这 些 路 由 的 属性 ，BGP 根 据 这 
些 属性 进行 路 由 的 选择 ;同时 Update 报 文 还 可 以 携带 多 条 不 可 达 路 
由 ， 被 撤销 的 路 由 放 在 Withdrawn Routes 字 段 中 。 


图 9-55 所 示 各 字段 解释 如 下 : 


口 Unfeasible routes length: 不 可 达 路 由 字段 的 长 度 ， 占 2 字 节 ， 以 
字 太 为 单位 。 如 果 为 0 则 说 明 没 有 Withdrawn routes 字 段 。 


口 Withdrawn routes: 不 可 达 路 由 的 列表 ， 可 变 长 度 。 


口 Total path attribute length: 路 径 属性 字段 的 长 度 ， 占 2 字 节 ， 以 字 
万 为 单位 。 如 果 为 0 则 说 明 没 有 Path attributes 字 段 。 


口 Path attributes: 与 NLRI 相 关 的 所 有 路 径 属性 列表 ， 每 个 路 径 属 
性 由 一 个 TLV (Type-Length-Value) 三 元 组 构成 ， 可 变 长 度 。BGP 正 是 
根据 这 些 属 性 值 来 避免 环 路 、 进 行 选 路 、 协 议 扩展 。 


DNLRI (Network Layer Reachability Information) : 可 达 路 由 的 前 
级 和 前 级 长 度 二 元 组 ， 可 变 长 度 。 


3.Notification 消 息 及 报 文 格式 


当 BGP 检 测 到 错误 状态 时 ， 就 向 对 等 体 发 出 Notification (通知 ) 消 
息 ， 之 后 BGP 连 接 会 立即 中 断 。 其 消息 报 文 格式 如 图 9-56 所 示 。 


0 7 15 31 


Error code Error subCode | 


Data 


图 。9-56 ”BGP Notification 消 息 报 文 格式 


图 9-55 所 示 各 字段 解释 如 下 : 


DError code: 差错 码 ， 占 1 字 廊 ， 指 定 错误 类 型 。 


口 Error subcode: 差 销 子 码 ， 占 1 字 节 ， 描 述 销 误 类 型 鸣 详细 信 


DData: 错误 消息 内 容 ， 可 变 长 度 ， 用 于 辅助 发 现 错误 的 原因 ， 它 
的 内 容 依赖 于 具体 的 差错 码 和 差错 子 码 ， 记 录 的 是 出 错 部 分 的 数据 。 


4.Keepalive 消 恩 报 文 格式 


BGP 会 周期 性 地 向 对 等 体 发 出 Keepalive (保持 活跃 ) 消息 ， 用 来 
保持 连接 的 有 效 性 。 其 消 居 格式 中 只 包含 图 9-53 所 示 的 BGP 消 居 报 头 ， 
没有 附加 其 他 任何 字段 。 


5.Route-refresh 消 妃 报 文 格式 


Route-refresh (路 由 刷新 ， 消息 用 来 要 求 对 等 体重 新 发 送 指定 地 址 
复 的 路 由 信息 。 其 消息 格式 如 图 9-57 所 示 。 


图 。 9-57 BGP Route-refresh 消 息 报 文 格式 


图 9-57 所 示 各 字段 解释 如 下 : 


口 AFI:，Address Family Identifier， 地 址 艇 标识 ， 占 2 字 节 ， 用 于 标 
识 所 采用 的 地 址 篮 类 型 。 


口 Res.: 保留 ， 占 1 字 和 ， 必 须 置 0。 


口 SAFI: Subsequent Address Family Identifier， 子 地 址 入 标识 ， 占 1 
字 忆 ， 用 于 标识 子 地 址 禾 类 型 。 


在 多 协议 BGP 中 支持 多 种 三 层 地 址 复 ， 如 IPv4、IPv6、CLNS、 
VPNv4 和 L2VPN 地 址 复 。AFI 和 SAFI 两 个 字段 是 多 协议 BGP 中 用 来 区 分 
不 同 网络 层 协议 的 地 址 簇 编 号 。 和 见 的 地 址 复 和 子 地 址 簇 标 识 如 表 9-9 
所 示 。 


表 9-9 常用 地 址 簇 类 型 的 AFIl 和 SAFI 


BGP 地 址 签 类 型 AFI SAFI 
ET EE 
IPv4 组 播 | | 2 
Ipv6 单 所 ! 
IPv4 MDT (组 播 分 布 树 ) | 66 
IPv6 组 播 2 
VPLS (rfc4761) 65 


第 10 章 ”传输 层 


“传输 层 ” 与 “数据 链 路 层 ” 的 作用 都 是 建立 数据 传输 通道 ， 两 者 在 功 
能 上 存在 许多 相似 之 处 。 传 输 层 的 功能 主要 体现 在 广域网 网 络 应 用 
中 ， 可 以 把 “数据 链 路 层 ” 当 做 局 域 网 通信 的 数据 传输 通道 ， 而 “传输 
层 ” 则 是 广域网 中 的 数据 传输 通道 。 本 章 主要 针对 广域网 中 的 传输 层 来 
进行 各 方面 功能 原理 的 介绍 。 但 是 ， 在 局 域 网 中 的 网 络 应 用 同样 需要 
用 到 传输 层 功能 ， 也 是 由 用 户 计算 机 操作 系统 中 TCP 或 UDP 来 完成 的 ， 
不 同 之 处 在 于 ， 在 局 域 网 中 ， 传 输 连接 是 永久 连接 ， 因 为 局 域 网 中 的 
数据 链 路 是 永久 连接 的 ， 又 不 需要 与 其 他 网 络 进 行 连接 。 


“传输 层 ” 是 整个 广域网 网 络 体系 结构 模型 的 核心 所 在 ， 因 为 它 负 
员 闻 到 逆 的 通信 ， 是 面向 网 络 通 信 的 低 三 层 和 面向 信息 处 理 的 高 三 层 
之 间 的 中 间 一 层 ， 起 到 桥梁 作用 。“ 传 输 层 ”同时 是 两 台 计 算 机 系统 经 
过 网 络 进行 数据 通信 时 第 一 个 端 到 端的 层次 。 本 章 主 要 介绍 OSIRM 中 
的 传输 层 协 议和 TCP/IP 体 系 结构 中 TCP 的 各 种 功能 (主要 包括 传输 连接 
建立 /释放 、 数 据 传输 、 差 错 控制 、 流 量 控制 、 拥 塞 控制 等 ) 的 实现 原 
理 。 


10.1 ”传输 层 概 述 


在 整个 网 络 体系 结构 中 ， 通 党 是 将 OSUVRM 七 层 模 型 中 的 下 面 三 层 
称 为 面向 通信 子 网 的 层 ， 负 责 通 信 通 道 的 建立 ， 而 将 传输 层 及 以 上 的 
各 层 称 为 面向 资源 子 网 的 层 ， 负 责 终端 系统 间 的 数据 通信 。 还 有 一 种 
划分 方式 ， 即 将 “传输 层 ? 及 以 下 的 三 层 统称 为 面向 通信 的 层 ， 总 体 来 
说 ， 负 责 通 信 通 道 的 建立 和 数据 传输 ， 而 将 “会 话 层 "\“ 表 示 层 "和 “应 
用 层 ” 这 些 不 包含 任何 数据 传输 功能 的 层 统称 为 面向 应 用 的 层 ， 如 图 10- 
1 所 示 。 


传输 层 


网 络 层 


数据 链 路 层 


图 10-1 传输 层 在 OSIURM 模 型 中 的 特殊 位 置 


10.1.1 划分 传输 层 的 必要 性 


从 通信 和 信息 处 理 两 方面 来 看 , “传输 层 ” 既 是 面 癌 通信 部 分 的 最 
高 层 ， 与 下 面 的 三 层 一 起 共同 构建 进行 网 络 通信 所 需 的 线路 和 数据 传 
输 通道 ， 同 时 又 面 癌 用 户 的 最 低层 ， 因 为 无 论 何 种 网 络 应 用 ， 最 终 
都 需要 把 各 种 数据 报 传送 到 对 方 。 来 和 目 应 用 层 的 用 户 数据 必须 依靠 伟 
输 层 协议 在 不 同 网 络 中 的 主机 间 进 行 传输 ， 因 为 仅 靠 网 络 层 把 数据 传 
送 到 目的 主机 上 还 是 不 够 的 ， 还 必须 把 它 交 给 目的 主机 的 应 用 进程 。 
因此， 无 论 “ 传 输 层 ”使 用 哪 种 划分 方式 ， 它 的 位 置 都 非常 符 殊 ， 部 起 
到 一 个 承 上 局 下 的 桥梁 作用 。 


下 面 再 从 数据 通信 原理 方面 具体 分 析 各 层 的 基本 作用 ， 从 而 体会 
划分 “传输 层 ” 的 必要 性 。 物 理 层 为 数据 通信 提供 实际 的 物理 线路 和 通 
信 信 道 ， 这 古 任 何 数 据 通 信 的 基础 ， 数 据 链 路 层 为 同一 网 络 中 (数据 
链 路 层 的 通信 限于 同一 局 域 网 中 ) 的 数据 通信 提供 了 虚拟 的 通信 通 
道 ， 可 以 根据 不 同 链 路 类 型 对 物理 层 的 比特 流 进行 帧 封 流 和 传输 ， 网 
络 计 为 不 同 网 络 间 的 数据 通信 提供 了 数据 包 的 路 由 、 转 发 功能 ， 把 数 
据 包 从 一 个 网 络 中 的 主机 传送 到 位 于 另 一 网 络 中 的 目的 主机 上 ， 其 中 
需要 选择 传送 的 最 佳 路 径 。 这 时 ， 可 能 就 有 读者 会 问 到 ， 既 然 网 络 层 
已 把 源 主 机 上 发 出 的 数据 包 传 送 给 了 目的 主机 ， 那 么 为 什么 还 需要 设 
置 一 个 传输 层 呢 ? 这 就 需要 我 们 理解 主机 间 用 户 应 用 层 通信 的 实体 
了 。 


位 于 两 台 网 络 主机 间 的 真正 数据 通信 主体 不 是 这 两 台 主 机 ， 而 十 
两 全 主机 中 的 各 种 网 络 应 用 进程 。 因 为 在 同一 时 刻 ， 两 主机 间 可 以 进 
行 多 个 应 用 通信 。 例 如 ， 某 两 个 用 户 在 进行 视频 通信 时 ， 还 可 以 进行 
QQ 聊天 ， 长 至 可 以 同时 打 网 络 电话 ， 这 束 是 多 个 应 用 进程 ， 如 图 10-2 
所 示 〈 仅 列 出 了 一 个 方向 ) 。 而 不 同 通信 的 标识 就 是 进程 ， 只 有 通信 
进程 才 可 以 把 对 应 的 数据 包 传 输 到 对 应 的 应 用 中 。 正 因为 如 此 ， 在 运 
行 具 体 的 网 络 通信 应 用 时 ， 必 须 为 每 一 个 网 络 应 用 配备 一 个 唯一 的 应 
用 进程 标识 ， 否 则 所 传输 的 报 文 束 不 知道 要 提交 给 哪个 用 户 应 用 了 。 
而 这 里 的 应 用 进程 识别 束 要 依靠 本 章 所 要 介绍 的 “传输 层 " 了 ， 它 束 是 
通过 “只 口 ? 将 不 同 应 用 进程 进行 对 应 的 。 


QQ 聊天 QQ 聊天 
视频 通信 局 应 用 层 -一 | ?网络 电话 视频 通信 所 应 用 层 -一 ;网络 电话 
入 
表示 层 表示 层 
会 话 层 会 话 层 
逻辑 上 的 对 等 传输 
入 输 层 。 am 传输 层 
网 络 层 网 络 层 网 络 层 网 络 层 
数据 链 路 层 数据 链 路 层 数据 链 路 层 数据 链 路 层 
物理 层 | 物理 层 物理 层 物理 层 
1 个 人 


图 10-2 多 应 用 进程 的 网 络 通信 流程 示意 图 


不 同 网络 间 主机 的 整体 通信 过 程 基本 如 下 : 在 一 个 用 户主 机 的 应 
用 层 发 出 的 应 用 请 求 报 文 到 了 传输 层 后 ， 在 数据 的 头 部 添加 对 应 的 传 
输 层 协议 头 部 信息 (具体 内 容 将 在 本 章 后 面 介绍 ， 将 其 封装 成 数据 


段 ， 然 后 传 到 网 络 层 后 封装 在 报 文 《或 者 报 文 分 组 ) 中 的 “数据 ?部 
分 ， 再 依次 传 到 数据 链 路 层 ， 重 痢 封 阎 成 数据 帆 ， 最 后 通过 物理 层 以 
比特 流 的 方式 一 位 位 地 同 对 方 网 络 传 输 。 传 送 到 对 方 网 络 中 后 ， 数 据 
沿 着 与 发 送 端 相反 的 方向 进行 解 封 装 ， 然 后 依次 传输 到 对 应 的 传输 
层 ， 最 后 提交 给 应 用 层 中 的 相应 应 用 进程 。 如 采 中 间 经 过 多 个 路 由 
如 ， 则 这 些 中 间 路 由 絮 只 进行 最 低 三 层 的 报 文 封 汉 和 解 封 疙 ， 以 及 其 
他 对 应 功能 ， 不 建立 基于 传输 层 的 对 等 连接 关系 。 


“传输 层 "是 源 端 到 目的 端 对 数据 传送 进行 控制 的 从 低 到 高 的 最 后 
一 层 ， 最 终 目 标 就 是 向 它 的 用 户 〈 应 用 层 中 的 应 用 进程 ) 提供 高 效 、 
可 靠 和 性 价 比 合理 的 服务 。 在 传输 层 内 部 ， 完 成 这 项 任务 的 硬件 或 软 
件 称 为 传输 实体 (transport entity) 。 传输 实体 可 能 位 于 操作 系统 的 内 
核 ， 或 者 在 一 个 独立 的 用 户 进 程 中 ， 或 者 以 一 个 链接 库 的 形式 被 绑 定 
在 具体 的 网 络 应 用 中 。 网 络 层 、 传 输 层 和 应 用 层 之 间 的 关系 如 图 10-3 所 
示 (其 中 的 TPDU 为 传输 协议 数据 单元 。 但 是 只 有 资源 子 网 中 的 终端 
设备 才 具 有 传输 层 功能 ， 通 信子 网 中 的 设备 一 般 至 多 只 具备 OSURM 低 
3 层 的 功能 ， 即 通信 功能 。 


主机 A 主机 B 


应 用 层 (包括 应 用 层 (包括 
表示 层 和 会 话 层 ) 表示 层 和 会 话 层 ) 


图 10-3 网 络 层 、 传 输 层 和 应 用 层 的 关系 


10.1.2 ”传输 层 的 病 到 病 传 输 服 务 


也 许 有 人 会 说 ， 传 输 层 的 主要 作用 束 古 为 它 的 上 层 提 供 端 到 端的 
数据 传输 服务 。 那 么 ， 什 么 叫 问 到 端 服务 呢 ? 其 实 这 里 面包 含 两 层 合 
义 : 第 一 层 舍 义 是 从 物理 的 网 络 连 接 角 度 来 讲 的 ， 即 问 到 端 是 指 网 络 
通信 的 双方 不 是 在 同一 链 路 上 ， 不 是 点 对 点 连接 的 ; 第 二 层 售 义 是 从 
虚拟 的 传输 连接 角度 来 讲 的 ， 即 端 到 端 是 指 在 用 户 看 来 两 端的 连接 是 
直接 进行 的 《其实 并 不 是 这 样 的 ，， 屏 项 了 核心 网 络 结构 和 各 种 子 网 
间 的 差异 。 当 然 ， 这 也 是 体系 结构 中 经 常 讲 的 “对 等 通信 ”原理 。 


这 里 涉及 两 个 概念 ， 即 “点 对 点 ” (Point-to-Point) 连接 和 “ 庙 到 
端 ” (end-to-end) 连接 。 所 谓 “ 点 对 点 ”连接 就 是 通信 双方 直接 通过 电 
缴 进 行 的 连接 ， 也 就 是 通常 所 说 的 背 对 背 连 接 ， 中 间 没 有 经 过 任何 其 
他 设备 。 如 图 10-4 所 示 ， 路 由 器 R1 与 主机 A、R2 与 主机 B、R3 与 主机 C 
这 三 对 之 间 的 连接 ， 以 及 R 与 R2、R1 与 R3、R2 与 R3 这 三 对 之 间 的 连接 
都 属于 点 对 点 连接 ， 因 为 在 这 些 连 接 链 路 的 中 间 没 有 任何 其 他 设备 。 
而 “ 端 到 端 ? 连 接 是 两 个 终端 系统 之 间 的 连接 ， 体 现在 两 个 终端 系统 的 
连接 中 时 要 经 过 一 个 或 多 个 设备 。 如 图 10-4 所 示 ， 主 机 A 与 主机 B、 主 
机 C 与 主机 A、 主 机 B 与 主机 C 这 三 对 之 间 的 连接 都 属于 “ 端 到 端 ? 连 
接 ， 它 们 之 间 都 经 过 了 一 个 或 多 个 路 由 器 的 转 连 。 


10-4 “点 对 点 ?连接 与 “器 到 端 ? 和 连接 示例 


与 “ 氮 对 点 "连接 和 “器 到 端 ? 连 接 相 对 应 的 是 “点 对 点 ”传输 和 "“ 端 到 
端 ” 传 输 。 在 进行 数据 传输 前 ，“ 响 到 端 ? 传 输 需要 在 两 哨所 经 过 的 线路 
上 建立 一 条 构建 于 网 络 层 已 搭建 好 的 路 由 路 径 之 上 的 虚拟 传输 连接 
(当然 ， 这 里 仅 古 针对 面向 连接 的 传输 层 协 议 而 讲 的 ) ， 以 此 来 屏蔽 
所 经 网 络 类 型 或 参数 配置 的 不 同 ， 吏 像 它们 十 直接 相连 的 一 样 ， 链 路 
建立 后 ， 源 端 吏 可 以 发 送 数据 ， 直 至 数据 发 送 完毕 ， 接 收 端 确认 接收 
成 功 。 


“ 融 到 端 ? 传 输 的 优点 是 链 路 建立 后 源 端 知道 接收 设备 一 定 能 收 到 
(这 就 是 “可 靠 性 ”的 体现 ) ， 而 且 经 过 中 间 交 换 设备 时 不 需要 进行 存 
储 转 发 ， 无 须 建立 多 条 传输 链 路 ， 因 此 传输 延迟 小 。“ 问 到 端 ?传输 的 
缺点 是 直到 目的 器 收 到 数据 为 止 ， 源 喘 的 设备 一 直 要 参与 传输 ， 因 为 


只 有 在 传输 完成 后 ， 从 源 端 到 目的 端 所 建立 的 虚拟 传输 连接 才能 “ 拆 

除 ”， 否 则 会 中 途中 断 数据 的 传输 。 这 样 一 来 ， 如 采 整 个 传输 的 延迟 很 
长 ， 那 么 对 源 端 的 设备 会 造成 很 大 的 痕 费 ， 因 为 那 时 源 端 可 能 早 殉 把 
所 有 数据 都 发 完了 ， 只 是 因为 中 间 子 网 的 一 些 延 迟 原 因而 导致 接收 站 
长 时 间 没 有 接收 完 数据 ， 最 终 导 人 致 传输 连接 不 能 释放 。“ 曾 到 端 ” 传 输 
的 男 一 个 缺点 是 ， 如 末 接 收 设备 天 机 或 故障 ， 那 么 端 到 端 传输 不 可 能 
实现 ， 因 为 无 法 在 两 端 建立 一 条 虚拟 的 专用 传输 通道 。 


“点 到 点 ”传输 是 指 源 端 可 直接 把 数据 传 给 与 它 直 接 相 连 的 设备 ， 
在 需要 的 时 候 又 可 把 数据 传 给 与 之 直接 相连 的 下 一 台 设 备 ， 通 过 一 台 
台 直 接 相 连 的 设备 ， 把 数据 传 到 接收 端 。 很 显然 ， 这 十 一 种 接力 传输 
方式 。“ 扩 到 点 ”传输 的 优点 十 源 端 设备 送出 数据 后 ， 它 的 任务 已 经 完 
成 ， 不 需要 参与 整个 传输 过 程 ， 这 样 不 会 当 费 源 端 设备 的 资源， 后 面 
的 数据 传输 是 由 后 面 的 设备 来 完成 的 。 另 外 ， 即 使 接收 端 设 备 关 机 或 
故障 ， 点 到 点 传输 也 可 以 采用 存储 转发 撤 术 进 行 缓冲 ， 当 然 缓冲 也 是 
有 大 小 和 时 间 限 制 的 。“ 点 到 点 ”传输 的 缺点 是 源 端 发 出 数据 后 ， 不 知 
道 目 的 端 能 否 收 到 或 何 时 能 收 到 数据 ， 因 为 它 不 需要 事 允 与 对 方 建立 
和 连接， 数据 发 送 也 是 以 数据 报 方式 进行 的 ， 即 不 管 对 方 是 否 工作 正 稼 
都 把 数据 发 送 过 去 。 


在 一 个 网 络 系统 的 不 同 层 次 中 ， 可 能 用 到 问 到 端 传输 ， 也 可 能 
到 点 到 点 传输 。 例 如 在 Internet 中 ， 网 络 层 及 以 下 各 层 都 采用 点 到 点 传 


输 ， 传 输 层 以 上 采用 端 到 端 传输 。 


10.1.3 ”传输 层 服务 


“传输 层 ” 在 通信 子 网 提供 的 服务 基础 上 ， 为 源 主机 和 目的 主机 之 
间 提 供 可 对 的、 透明 的 、 可 由 用 户 选 择 的 数据 传输 服务 ， 征 面 癌 用 户 
的 高 层 和 面向 通信 子 网 的 低层 之 间 的 软件 接口 ， 或 者 称 为 "桥架 ”。 同 
时 ， 传 输 层 也 弥补 了 高 层 所 要 求 的 可 靠 、 可 控制 服务 与 网 络 层 所 提供 
的 非 可 靠 服务 之 间 的 差距 ， 并 癌 高 层 屏 蔽 通信 子 网 中 不 同 网 段 的 差 


异 。 


1. 传 输 层 服务 类 型 


与 网 络 层 有 面向 连接 服务 和 无 连接 服务 两 大 类 一 样 (在 TCP/IP 体 
系 结构 中 只 有 无 连接 的 网 络 层 服务 ) ， 传 输 层 的 服务 也 有 这 两 大 类 。 
面向 连接 的 传输 服务 在 提供 传输 服务 前 需要 先 建立 专门 的 传输 连接 ， 
而 且 这 条 连接 是 可 管理 的 ， 在 需要 或 通信 结束 时 进行 拆除 。 面 向 连接 
的 传输 服务 是 可 车 的 传输 服务 ， 而 且 可 提供 拥塞 控制 和 差错 控制 功 
能 ， 如 TCP 提 供 的 传输 服务 。 无 连接 的 传输 服务 在 提供 服务 前 不 需要 建 
立 专 门 的 传输 连接 ， 直 接 回 目的 节点 发 送 数据 ， 不 管 是 否 有 可 传输 的 
通道 ， 只 提供 不 可 靠 〈 仅 做 尽力 传输 ) 的 传输 服务 ， 如 UDP 提供 的 传 


此 处 所 说 的 “ 面 问 连接 的 传输 服务 ”与 在 网 络 层 中 介绍 的 “ 面 癌 连接 
的 网 络 层 服务 ?十 分 相似 ， 两 者 都 问 用 户 提供 连接 的 建立 、 维 持 和 拆 
除 ， 而 且 无 连接 的 传输 服务 与 无 连接 的 网 络 层 服务 也 十 分 相似 。 那 
么 ， 有 既然 传输 层 服 务 与 网 络 层 服 务 如 此 相似 ， 又 为 什么 要 将 它们 划分 
成 两 个 层次 呢 ? 因 为 网 络 层 是 通信 子 网 的 一 个 组 成 部 分 ， 网 络 服务 质 
量 并 不 可 靠 ， 如 频 爱 地 丢失 分 组 ， 网 络 层 系统 可 能 月 并 或 不 断 地 进行 
网 络 复位 。 对 于 这 些 情 况 ， 用 户 将 束手无策 ， 因 为 用 户 不 能 对 通信 子 
网 加 以 控制 ， 因 而 无 法 采用 更 优 的 通信 处 理 机 来 解决 网 络 服务 质量 低 
务 的 问题 ， 更 不 能 通过 改进 数据 链 路 层 纠 错 能 力 来 改善 忆 。 解 决 这 一 
问题 的 唯一 可 行 方法 束 古 在 资源 子 网 的 主机 上 增加 一 个 可 以 由 用 户 控 
制 的 传输 层 。 通 过 传输 层 的 面向 连接 服务 ， 使 得 数据 传输 更 加 可 靠 ， 
特别 是 对 于 IP 这 类 无 连接 网 络 层 服务 。 


2. 服 务 等 级 


不 同类 型 的 网 络 ， 以 及 不 同 连接 性 能 的 网 络 ， 所 提供 的 传输 层 服 
务 级 别 也 不 一 样 。 


传输 层 提供 的 服务 可 分 为 “传输 连接 ”服务 和 “数据 传输 ”服务 。“ 传 
输 连 接 ” 服 务 是 传输 层 为 它 的 上 层 发 出 的 每 个 应 用 进程 在 网 络 层 提供 的 
服务 基础 之 上 建立 一 个 相应 的 逻辑 连接 ;而 “数据 传输 ”服务 则 是 在 所 
建立 的 传输 连接 基础 上 ， 为 用 户 提 供 比 网 络 层 更 有 保障 (主要 针对 面 


癌 对 用 户 的 传输 层 服 务 而 言 ) 、 更 有 针对 性 ， 并 且 能 由 用 户 自 己 进行 
拥塞 控制 、 有 差错 控制 的 数据 传输 。 


传输 层 所 能 提供 的 服务 质量 的 水 平 ， 不 仅 与 所 选择 的 传输 层 协议 
有 关 ， 更 重要 的 是 与 所 服务 的 网 络 类 型 有 关 ， 毕 竟 传 输 层 是 建立 在 网 
络 层 基础 之 上 ， 依 赖 网 络 层 所 提供 的 路 由 服务 。 根 据 不 同 网 络 所 提供 
的 不 同 传输 层 服 务 质量 水 平 ， 可 把 传输 层 服 务 分 为 以 下 三 大 类 。 


口 A 类 : 具有 低 的 连接 差错 率 和 故障 率 ， 是 可 靠 的 传输 服务 ， 一 般 
在 虚 电 路 网 络 上 。 


口 B 类 : 具有 较 低 的 连接 差错 率 和 故障 率 ， 传 输 服 务 质量 中 等 ， 应 
用 于 广域网 和 互联 网 中 的 传输 层 协议 多 数 属于 这 一 类 。 


口 C 类 : 具有 较 高 的 连接 差错 率 和 故障 率 ， 服 务 质量 较 差 ， 提 供 数 
据 报 服务 或 无 线 电 分 组 交换 网 所 提供 的 传输 层 协议 均 属 此 类 。 


3. 传 输 层 协议 类 别 


在 OSURM 体 系 结构 的 传输 层 中 ， 不 同类 型 的 传输 层 协议 所 文 持 的 
服务 级 别 不 一 样 ， 共 分 TP0~TP4 五 种 类 型 。 其 中 ，TP0~TP3 这 四 种 类 别 
均 属 于 面向 连接 的 传输 层 协议 ， 发 送 数据 前 必须 先 建立 传输 连接 ，TP4 
既 可 以 是 面向 连接 的 传输 层 协议 ， 也 可 以 是 无 连接 的 传输 层 协 议 。 


DTP0: 简单 类 ， 只 建立 一 个 简单 的 端 到 端 传输 和 连接， 提供 基本 的 
数据 段 和 重组 功能 。TP0 传 输 层 协议 先 识别 网 络 层 所 文 持 的 最 大 传输 单 
元 (MTU) 大 小 ， 然 后 据 此 在 必要 时 对 数据 包 进 行 分 段 ， 在 接收 端 再 
对 数据 段 进行 重组 。 


口 TP1: 基本 差错 恢复 类 ， 在 TP0 基 础 上 新 增 了 差错 控制 功能 ， 可 
以 对 每 个 TPDU 进 行 编号 ， 当 收 到 不 确认 (NAK) 消息 或 者 有 TPDU 丢 
失 时 将 会 重 发 ， 如 果 有 太 多 的 不 确认 TPDU，TP1 类 别 的 传输 层 协议 还 
可 重新 初始 化 传输 连接 。 


口 TP2: 多 路 复 用 类 ， 在 TP0 基 础 上 新 增 了 传输 连接 多 路 复 用 和 解 
复 用 功能 ， 以 及 流量 控制 功能 。 


口 TP3: 差错 恢复 和 多 路 复 用 类 ， 是 TP1 和 TP2 传 输 层 协议 功能 的 


法 
D> 


DTP4: 差错 检测 和 恢复 类 ， 在 TP3 基 础 上 新 增 差错 检测 功能 ， 是 
最 复杂 的 传输 层 协 议 类 型 。 在 功能 上 ， 类 似 于 TCP/IP 体 系 结构 中 的 
TCP， 但 TP4 类 别 的 传输 层 协议 既 文 持 面 向 连接 的 网 络 服务 ， 也 文 持 无 
连接 的 网 络 服务 。 


上 上述 这 五 种 传输 层 协 议 类 别 的 绿 合 比较 如 表 10-1 所 示 。 


表 10-1 五 种 传输 层 协 议 类 别 的 综合 比较 


协议 ETEEE 
TP0 数据 段 和 重组 
TP1 数据 段 和 重组 、 差 错 控制 
面向 连接 的 传输 层 协 议 
TP2 数据 段 和 重组 、 多 路 利用 和 解 复 用 由 


TP3 数据 段 和 重组 、 差 错 控制 、 多 路 利用 和 解 复 用 
TP4 数据 段 和 重组 、 差 错 控制 、 多 路 利用 和 解 复 用 、 差 错 检测 | ， 既 可 以 是 面向 连接 的 传输 层 协议 ， 


也 可 以 是 无 连接 的 传输 层 协 议 


10.1.4 TSAP 和 TPDU 


在 OSVRM 体 系 结构 的 传输 层 中 ， 涉 及 两 个 非 第 重要 的 术语 
TSAP (传输 服务 访问 点 ) 和 TPDU (传输 协议 数据 单元 ， 它 们 贯穿 
整个 传输 层 数 据 传输 服务 的 始末 。 下 面具 体 介绍 一 下 这 两 个 术语 。 


1.TSAP 


在 计算 机 网 络 中 ， 传 输 层 要 在 用 户 之 间 提 供 可 靠 、 有 效 的 端 到 端 
服务 ， 必 须 把 一 个 用 户 进 程 和 其 他 的 用 户 进 程 区 分 开 ， 这 个 工作 主要 
就 是 由 传输 层 地 址 来 完成 了 。 在 本 书 第 5 章 介绍 数据 链 路 层 时 就 讲 过 ， 
不 同 层 间 之 间 的 互 访 是 通过 SAP (服务 访问 点 ) 进行 的 。SAP 位 于 除 最 
高 的 应 用 层 外 其 他 各 层 的 上 边缘 ， 用 来 为 下 层 向 上 层 提供 服务 ， 同 时 
是 上 层 调 用 下 层 服务 的 逻辑 接口 。 在 传输 层 的 上 边缘 也 有 对 应 的 SAP 

(而 且 可 能 远 不 止 一 个 ) ， 那 就 是 TSAP。TSAP 是 上 层 调 用 传输 层 服 
务 ， 以 及 传输 层 为 它 的 上 层 提供 服务 的 逻辑 接口 ， 是 传输 层 地 址 ， 如 
图 10-2 所 示 。 


同一 时 间 、 同 一 对 网 络 实体 间 的 用 户 应 用 进程 可 能 有 多 个 ， 不 能 
仅 靠 网 络 实体 地 址 〈 即 NSAP) 来 标注 通信 双方 《因为 此 时 通信 的 实体 
征 各 个 应 用 进程 ， 而 不 是 通信 双方 主机 ) ， 而 必须 借助 传输 层 地 址 进 


行 标 识 。TSAP 相 当 于 传输 层 的 地 址 ， 不 同 的 TSAP 标 识 不 同 的 会 话 或 
应 用 进程 。 


为 确保 所 有 的 传输 地 址 在 整个 网 络 中 是 唯一 的 ， 因 此 将 传输 地 址 
分 成 网 络 ID、 主 机 ID 及 主机 分 配 的 端口 三 部 分 。 前 面 的 “网 络 ID” 和 “ 主 
机 ID? 这 两 部 分 正好 是 了 地址 的 两 部 分 ， 用 来 指定 具体 的 网 络 实体 ， 有 是 
NSAP 《网络 服 务 访 问 点 ) ; 后面 的 “ 冰 口 ?是 传输 改 特 定 的 属性 ， 用 来 
与 应 用 进程 进行 一 一 对 应 的 ， 所 以 说 真正 的 传输 层 地 址 其 实 就 是 具体 
应 用 所 占用 的 “ 滑 口 ”。 


值得 注意 的 是 ， 在 总 共 65535 个 对 应 传输 层 协 议 端口 中 ， 前 1024 个 
端口 被 称 为 常规 端口 ， 代 表 了 特定 的 应 用 层 服务 ， 或 者 说 是 应 用 层 进 
程 的 端口 号 ， 不 能 分 配给 其 他 应 用 服务 使 用 (其 他 的 端口 可 以 随意 使 
用 ) ， 而 且 同 一 时 间 、 同 一 主机 上 不 能 有 两 个 应 用 进程 使 用 相同 的 端 
口号 ， 因 此 ， 在 为 应 用 进程 分 配 端 口 时 不 能 随意 。 例 如 ， 将 80 号 TCP 端 
口 分 配给 了 WWW (对 应 HTTP 应 用 ) 服务 使 用 ， 将 23 号 TCP 端 口 分 配 
给 了 Telnet 服 务 使 用 ， 将 21 号 TCP 端 口 分 配给 了 FTP 服 务 使 用 等 。 


2.TPDU 


在 本 书 第 5 章 同 样 也 介绍 过 ， 在 分 层 的 网 络 体系 结构 中 的 每 一 层 都 
是 使 用 PDU (Protocol Data Unit， 协 议 数据 单元 ) 来 与 对 方 的 对 等 层 进 
行 通信 的 。PDU 包 含 来 自 上 层 的 信息 ， 以 及 当前 层 的 实体 附加 的 信 


忆 。 然 后 ， 这 个 PDU 被 传送 到 下 一 个 较 低 的 层 。 其 实 ， 在 其 他 层 中 我 
们 都 提 到 了 PDU 这 个 术语 ， 只 不 过 到 了 最 后 不 是 直接 说 是 菏 茶 PDU， 
而 十 为 各 层 起 了 一 个 专用 的 名 称 ， 如 在 数据 链 路 层 的 LLC 和 MAC 两 个 
子 层 中 所 说 的 “ 帧 就 分 别 对 应 了 LPDU (人 逻辑 链 路 协议 数据 单元 ) 和 
MPDU (介质 访问 协议 数据 单元 ) ， 另 外 ， 网 络 层 中 所 说 的 “分 

组 ”或 “ 包 ” 其 实 对 应 的 就 是 NPDU (网 络 协议 数据 单元 ) 。 但 到 了 传输 
层 ， 我 们 在 本 书 第 3 章 讲 过 ， 传 输 层 的 数据 单元 是 “数据 段 "， 这 个 名 称 
显然 太 容易 混淆 ， 于 是 在 OSRM 体 系 结构 的 传输 层 中 还 是 把 其 中 传输 
的 数据 单元 称 为 TPDU (不 过 ， 在 TCP/IP 体 系 结构 中 ，TCP 的 协议 数据 
单元 仍然 为 “数据 段 ") 。 其 实 ，TPDU 与 本 书 前 面 几 章 中 介绍 的 “ 比 
特 ”、“ 幅 “分 组 ”( 或 “ 包 ”) 是 同类 概念 。 


既然 TPDU 是 传输 层 的 协议 数据 单元 ， 那 么 它 与 数据 链 路 层 
的 “ 帧 ”及 网 络 层 的 “分 组 一样， 也 有 它 的 基本 格式 ， 即 由 “ITPDU 头 
部 ”和 “TPDU 有 效 载荷 "两 部 分 组 成 ， 与 其 他 层 中 的 PDU 基 本 格式 一 
样 。 其 中 ,，“TPDU 有 效 载 荷 * 是 来 自 会 话 层 (OSVRM 体 系 结构 中 ) 或 
应 用 层 (TCP/IP 体 系 结构 中 ) 的 数据 ， 而 “TPDU 头 部 ”由 “长 度 指 
示 ”(LI) 、“ 固 定 部 分 *、“ 可 变 部 分 ”三 个 基本 部 分 组 成 。 整 个 TPDU 的 
基本 结构 如 图 10-5 所 示 。 


固定 部 分 | 可 变 部 分 有 效 载荷 


《全 
TPDU 头 言 


图 10-5 TPDU 基 本 结构 


DLI: 占 1 字 节 ， 以 字 节 为 单位 标识 整个 TPDU 头 部 的 长 度 ， 最 大 
值 为 254 。 


口 固 定 部 分 : 包括 TPDU 代 码 和 常用 参数 ， 其 内 容 对 于 某 一 特定 的 
TPDU 来 说 是 固定 的 ， 如 包括 目的 端口 和 源 端 口 等 ， 但 是 不 同 传输 层 协 
议 的 TPDU 是 不 一 样 的 。 


口 可 变 部 分 : 包含 一 些 可 选 参数 项 ， 每 个 参数 项 由 三 个 字段 构 
成 : Code (代码 ，1 字 节 ) 、Length (长 度 ，1 字 节 ) 和 Value ( 值 , 长 
度 可 变 ) ， 也 就 是 通常 所 说 TLV。 因 为 可 变 部 分 的 各 构成 部 分 所 包含 的 
参数 项 数目 不 同 ， 所 以 其 长 度 是 可 变 的 。OSVRM 中 定义 的 常见 TPDU 
类 型 参数 以 及 它们 对 应 的 代码 值 如 表 10-2 所 示 。 


表 10-2 OSI/RM 中 定义 的 常见 TPDU 类 型 
适用 的 传输 协议 类 别 


ey me cal ein 
pc TT EE EE EE 
更 到 
配 卫 


协商 好 的 长 度 以 下 


V 0110 无 


E ee 


常见 TPDU 类 型 说 明 如 下 。 


口 CR (Connection Request， 连 接 请 求 ) : 向 对 端 发 送 的 面向 连接 
的 传输 连接 请 求 的 TPDU 。 该 类 TPDU 头 部 为 7 字 节 ， 整 个 TPDU 长 度 可 


口 CC (Connection Confirmn ， 连 接 确 认 ) : 向 连接 请 求 者 发 送 的 面 
向 连接 的 传输 连接 确认 的 TPDU。 该 类 TPDU 头 部 为 7 字 节 ， 整 个 TPDU 
长 度 可 变 。 


DDR (Disconnect Request， 断 开 连 接 请 求 ) : 向 对 端 发 送 的 断 开 
连接 请 求 的 TPDU。 该 类 TPDU 头 部 为 7 字 节 ， 整 个 TPDU 长 度 可 变 。 


DDC (Disconnect Confirm ， 断 开 连 接 确 认 ) : 向 连接 请 求 者 发 送 
的 断 开 连接 确认 的 TPDU。 该 类 TPDU 头 部 为 6 字 节 ， 整 个 TPDU 长 度 可 


DDT (Data， 数 据 ) : 向 对 端 发 送 的 真正 用 户 数据 的 TPDU。 该 类 
TPDU 头 部 为 3 字 世 ， 整 个 TPDU 长 度 可 变 。 


口 AK (Acknowledgement， 数 据 确认 ) : 向 数据 发 送 者 发 送 的 用 
户 数据 确认 的 TPDU， 指 出 希望 收 到 的 下 一 个 TPDU 号 。 该 类 TPDU 头 部 
为 5 字 节 ， 整 个 TPDU 长 度 可 变 。 


DED (Expedited Data， 加 速 数据 ) : 向 对 端 发 送 的 加 速 数据 的 
TPDU。 该 类 TPDU 将 优先 普通 用 户 数据 TPDU 发 送 ， 其 中 TPDU 头 部 为 


5 字 节 ， 整 个 TPDU 长 度 可 变 。 


口 EA (Expedited data Acknowledgement， 加 速 数 据 确认 ) : 向 加 
速 数据 发 送 者 发 送 的 加 速 数据 确认 的 TPDU。 该 类 TPDU 将 优先 普通 用 
户 数据 确认 TPDU 发 送 ， 其 中 TPDU 头 部 为 5 字 节 ， 整 个 TPDU 长 度 可 


口 RJ (Reject， 拒 绝 ) : 向 连接 请 求 者 发 送 的 拒绝 连接 请 求 的 
TPDU。 该 类 TPDU 头 部 为 5 字 节 。 


DER (Error， 错 误 ) : 向 数据 发 送 者 发 送 的 数据 错误 的 TPDU， 
表示 所 收 到 的 对 应 TPDU 有 错误 。 该 类 TPDU 头 部 为 5 字 节 ， 整 个 TPDU 
长 度 可 变 。 


具体 来 说 ，TPDU 头 部 的 后 两 部 分 要 对 应 具体 的 传输 层 协 议 (也 就 
是 上 文 所 说 的 TP0~TP4) 才 有 意义 。 但 无 论 是 哪 种 TPDU， 在 发 送 端 都 
要 自 上 而 下 传输 ， 到 了 网 络 层 后 同样 要 经 过 网 络 层 协 议 的 封装 ， 形 成 
分 组 ， 然 后 继续 向 下 传输 到 数据 链 路 层 ， 最 后 封装 成 帧 。TPDU 的 逐 层 
封装 示意 图 如 图 10-6 所 示 。 


传输 层 | TPDU 头 部 TPDU 有 效 载 答 


网 络 层 分 组 有 效 载荷 
数据 链 路 层 | 帧 头 帧 有 效 载 答 


图 。10-6 TPDU 的 逐 层 封装 示意 图 


10.1.5 ”传输 连接 建立 阶段 的 主要 TPDU 


从 本 节 开 始 介绍 一 些 主要 TPDU 格 式 ， 看 看 数据 传输 的 各 个 阶段 
使 用 了 哪些 主要 TPDU， 以 及 它们 所 包含 的 基本 内 容 是 什么 。 本 市 介 
绍 在 传输 连接 建立 阶段 所 用 的 主要 TPDU 格 式 。 


从 表 10-2 可 知 ， 在 传输 连接 建立 阶段 ， 主 要 用 到 了 CR (连接 请 
求 ) TPDU 和 CC (连接 确认 ) TPDU 两 种 。 


1.CR TPDU 


CR TPDU 的 基本 格式 如 图 10-7 所 示 ， 下 面 是 各 字段 的 说 明 〈 仅 说 
明 “ 回 定 部 分 ”) 。 


10-7 CR TPDU 格 式 


口 代 码 (Code) : 标识 TPDU 类 型 ， 占 4 位 ，CR TPDU 的 代码 值 为 
1110 。 


口 CDT (Credit Allocation) : 信用 量 分 配 ， 表 示 能 接收 的 TPDU 序 
号 的 上 限 值 (上 暗示 了 可 接收 的 TPDU 数 量 ) ， 占 4 位 。CDT 类 似 于 本 章 
后 面 在 介绍 TCP 数 据 段 格式 中 所 说 到 的 “窗口 大 小 ”字段 ， 对 端 通 过 对 


CDT 字 段 值 的 识别 以 改变 当前 的 发 送 窗口 大 小 。TPDU 中 的 CDT 字 段 
与 TCP 数 据 段 的 “窗口 大 小 ”字段 一 样 均 用 于 流量 控制 ， 其 基本 原理 类 
似 于 数据 链 路 层 和 网 络 层 的 滑动 窗口 式 流量 控制 。CR TPDU 中 的 CDT 
属于 初始 信用 量 ， 在 传输 连接 建立 时 双方 协商 确定 。 


口 目 的 参考 (DST Reference) : 指 该 传输 连接 的 目的 端 对 等 传输 
实体 用 来 唯一 标识 这 一 连接 的 标识 符 ， 也 就 是 对 端 传输 连接 序号 ， 占 
16 位 。CR TPDU 中 的 “目的 参考 ”为 全 0， 因 为 连接 尚未 建立 (正在 请 
求 中 ) ， 将 由 目的 端 选择 。 


口 源 参考 (Source Reference) : 本 地 传输 连接 标识 符 ， 也 就 是 本 
地 传输 连接 的 序列 号 ， 占 16 位 。 


说 明 在 传输 连接 的 每 一 端 ， 源 TSAP 地 址 和 目的 TSAP 地 址 写 在 
CR TPDU 头 部 的 可 变 部 分 中 。 当 目的 端 要 对 收 到 的 CR TPDU 表 示 确 
认 ， 并 同意 建立 传输 连接 时 ， 束 会 发 回 CC TPDU， 其 中 也 包含 了 * 源 
参考 ”和 “目的 参考 ”这 两 个 字段 值 。 但 此 时 CC TPDU 中 的 “ 源 参 
考 ” 和 “目的 参考 ”都 是 针对 发 送 CC TPDU 的 端点 而 言 的 ， 所 以 其 中 
的 “ 源 参考 ”也 即 为 在 CR TPDU 中 以 全 0 格式 填充 的 “目的 参考 *。 通 过 这 
样 两 次 握手 过 程 ， 双 方 就 知道 了 各 自 的 传输 连接 序号 了 。 


口 类 别 选 项 ， 占 8 位 ， 高 4 位 标识 使 用 的 传输 层 协议 类 型 
(TP0~TP4) ; 低 4 位 是 可 选项 ， 用 来 说 明 在 DATA TPDU 和 AK TPDU 


中 的 序号 字段 是 正常 的 ， 还 是 扩展 的 ， 正 常 为 0000， 扩 展 为 0010。 通 
常 TPDU 序 号 只 有 7 位 ， 但 对 于 TP2~TP4 传 输 层 协议 来 说 ， 序 号 可 以 扩 
展 到 32 位 。 


协议 和 序号 类 型 都 是 可 协商 的 ， 但 在 协商 过 程 中 ， 服 务 质 量 只 能 
降低 而 不 允许 提高 。 协 商 后 的 数值 通过 CC TPDU 返 回 到 源 端 。 例 如 ， 
CR 的 发 送 端 选择 了 TP4 ( 值 为 1000) ，CC 的 发 送 端 可 以 将 它 降 低 为 
TP2 (0010) 。 但 若 CR 的 发 送 端 选择 的 是 TP2， 则 CC 的 发 送 端 不 能 将 


它 改 为 TP4。 


CR TPDU 头 部 可 变 部 分 可 包括 TPDU 最 大 长 度 、 源 TSAP ID、 目 
的 TSAP ID、 安 全 参数 、 校 验 和 、QoS 参 数 等 ， 具 体内 容 不 作 介 绍 。 


2.CG TPDU 


CC TPDU 的 格式 与 CR TPDU 类 似 (参见 图 10-7) ， 不 同 的 只 是 
CC TPDU 中 的 “代码 ”字段 为 1101， 代 表 为 CC TPDU， 同 时 “目的 参 
考 ” 字 段 不 再 是 16 位 全 0， 而 是 发 起 连接 端的 传输 连接 序列 号 ， 即 CR 
TPDU 中 的 “ 源 参 考 号 ”， 它 是 提供 服务 的 传输 连接 序号 。 


10.1.6 ”数据 传输 阶段 的 主要 TPDU 


从 表 10-2 可 知 ， 在 传输 连接 建立 阶段 ， 主 要 用 到 了 DT (数据 ) 
TPDU、AK (数据 确认 ) TPDU、ED (加 速 数据 ) TPDU 和 EA (加 速 
数据 确认 ) TPDU 四 种 。 这 里 要 特别 注意 的 一 点 是 ， 在 所 有 TPDU 中 ， 
只 有 DT TPDU 和 ED TPDU 才 有 “TPDU 序 列 号 ”字段 ， 也 就 是 只 有 这 两 
种 TPDU 才 会 进行 编号 ， 其 他 TPDU 均 不 编号 ， 男 外 ， 只 有 AK TPDU 和 
EA TPDU 才 有 “你 的 序列 号 ”字段 ， 其 他 TPDU 均 没有 该 字段 。 


1.DT TPDU 


DT TPDU 是 数据 传输 的 TPDU。 在 DT TPDU 中 ， 选 择 使 用 的 传输 
层 协议 类 型 不 同 ， 对 应 的 格式 也 不 一 样 。 当 选择 TPO 和 TP1 类 型 传输 协 
议 时 ， 它 的 格式 如 图 10-8 所 示 。 各 字段 说 明 如 下 〈 仅 说 明 * 固 定 部 


分 9 。 


0 7 位 


固定 
部 分 


TPDU 序 列 号 和 EOT 


用 户 数 据 


10-8 ”TPO 和 TP1 类 型 的 DT TPDU 格 式 


口 代码 : 标识 TPDU 类 型 ， 占 8 位 ，DT TPDU 的 代码 值 为 1111 
0000。 


DTPDU 序 列 号 和 EOT: 占 8 位 ， 高 7 位 标识 对 应 DT TPDU 的 序列 
号 ， 最 低位 (EOT 位 ) 用 来 标识 此 TPDU 是 否 是 某 个 数据 的 最 后 一 个 
数据 段 ， 等 于 1 时 表示 是 最 后 一 个 数据 段 。 


当选 择 TP2、TP3 和 TP4 类 型 传输 协议 时 ， 它 的 格式 要 分 两 种 情 
况 : 一 是 在 建立 传输 连接 时 选择 的 不 是 TP2~TP4 类 型 ， 此 时 的 TP2、 
TP3 和 TP4 类 型 DT TPDU 格 式 如 图 10-9 所 示 ; 二 是 如 果 在 建立 传输 连接 


时 也 选择 的 是 TP2~TP4 类 型 ， 此 时 的 TP2、TP3 和 TP4 类 型 DT TPDU 格 
式 如 图 10-10 所 示 。 


0 7 位 


部 分 


TPDU 序 列 号 和 EOT 


可 变 部 分 


用 户 数据 


10-9 ”建立 连接 时 未 选择 TP2~TP4 类 型 时 的 TP2~TP4 DT TPDU 
格式 


0 7 位 
,| 


| 
目的 参考 ( 16 位 ) 


部 分 


TPDU 序 列 号 和 EOT 


10-10 ”建立 连接 时 已 选择 TP2~TP4 类 型 时 的 TP2~TP4 DT TPDU 
格式 


在 以 上 两 种 情况 下 ，DT TPDU 格 式 的 主要 区 别 在 于 *TPDU 序 列 号 
和 EOT” 字 段 的 长 度 ， 图 10-9 中 的 为 8 位 ， 而 图 10-10 中 的 为 16 位 。 对 比 
10-8 可 以 看 出 ， 在 图 10-9 和 图 10-10 所 示 的 格式 中 ， 主 要 是 多 了 一 
个 “目的 参考 ”和 “可 变 部 分 ”。 因 为 TP2~TP4 类 传输 层 协议 支持 多 路 复 
用 ， 需 要 标识 各 传输 连接 号 ， 所 以 需要 “目的 参考 ”这 个 字段 ， 而 
TP0~TP1 类 型 传输 层 协 议 是 不 文 持 多 路 传输 连接 复 用 的 ， 所 以 即使 在 


传输 数据 时 不 标识 传输 连接 号 ， 也 不 会 出 现 差 错 。“ 目 的 参考 "字段 占 
16 位 ， 是 在 通过 CR TPDU 和 CC TPDU 建 立 传 输 连 接 过 程 中 获得 的 目的 
端 传输 连接 号 。 在 “可 变 部 分 ”中 包括 “ 校 验 和 ”参数 。 


2.AK TPDU 


AK TPDU 是 接收 端 在 收 到 源 端 发 来 的 DTTPDU 后 的 确认 TPDU 。 
它 的 TPDU 格 式 分 为 在 建立 传输 和 连接 时 没有 选择 具体 的 协议 类 型 时 
的 “正常 ”格式 和 在 建立 传输 连接 时 已 选择 TP1~TP4 类 型 传输 协议 时 
的 “扩展 ”格式 ， 分 别 如 图 10-11 和 图 10-12 所 示 。 两 者 的 主要 区 别 为 “ 代 
码 ”\“CDT” 和 “你 的 TPDU 序 列 号 ”3 个 字段 的 宽度 。 下 面 分 别 介绍 其 中 
的 各 个 字段 〈 仅 说 明 *“ 固 定 部 分 2) 。 


0 7 位 


固定 
目的 参考 〈16 位 ) 部 分 


你 的 TPDU 序 列 号 


10-11 正常 情况 下 的 AK TPDU 格 式 


0 7 位 


目的 参考 ( 16 位 ) 
固定 
部 分 


你 的 TPDU 序 列 号 (32 位 ) 


CDT ( 16 位 ) 


10-12 ”扩展 情况 下 的 AK TPDU 格 式 


口 代码 : 标识 TPDU 类 型 ， 在 正常 情况 下 占 4 人 位， 为 0110， 而 在 扩 
展 情况 下 占 8 位 ， 为 0110 0000， 代 表 AK TPDU 。 


DCDT: 信用 量 分 配 ， 用 于 流量 控制 ， 在 正常 情况 下 占 4 位 ， 而 在 
扩展 情况 下 占 16 位 。 


口 目 的 参考 ， 占 16 位 ， 是 数据 传输 产 端 的 传输 连接 序号 。 


口 你 的 TPDU 序 列 号 (YR-TU-NR，Your-TPDU-Number) : 表明 
所 期 望 接收 的 下 一 个 DT TPDU 的 序号 ， 这 也 隐 含 地 表示 对 该 序号 以 前 
的 各 DT TPDU 均 已 加 以 确认 ， 相 当 于 本 章 后 面 将 要 介绍 的 TCP 数 据 段 
中 “确认 号 ”字段 。 在 正常 情况 下 占 8 位 ， 而 在 扩展 情况 下 占 32 位 。 


为 了 避免 因 “YR-TU-NR” 字 段位 数 不 足 而 出 现 序 混乱 现象 ， 还 可 
以 利用 AK TPDU 中 的 “可 变 部 分 ”参数 的 “ 子 序 号 ”的 参数 (还 包括 “ 校 验 
和 ”和 “流量 控制 确认 ”参数 ) 进行 TPDU 序 号 标识 。 子 序号 的 使 用 规则 
如 下 : 


口 当 给 一 个 具有 更 高 序号 (也 就 是 *YR-TU-NR” 字 段 值 还 未 达到 
最 大 值 ) 的 DTTPDU 发 回 AK TPDU 时 ， 应 将 “ 子 序号 ”复位 置 0， 表 示 
不 采用 “ 子 序号 ”字段 。 


口 若 本 次 发 送 的 AK TPDU 的 “YR-TU-NR” 字 段 值 不 变 ， 只 是 信用 
量 CDT 字 上 段 值 增 大 了 ， 则 “ 子 序号 ”不 变 ， 即 与 上 次 发 送 的 AK TPDU 
的 “ 子 序号 ” 值 相 同 。 


口 若 本 次 发 送 的 AK TPDU 的 “YR-TU-NR”* 字 上 段 值 不 变 ， 但 信用 量 
CDT 字 上 段 值 减 小 了 ， 则 需要 在 上 次 发 送 的 AK TPDU 的 “ 子 序 号 ” 值 基础 
上 加 1 。 


在 接收 AK TPDU 的 一 端 ， 仅 在 以 下 情况 时 才 将 AK TPDU 收 下 : 


口 它 所 确认 的 DT TPDU 的 序号 比 上 次 收 到 的 高 。 


口 它 所 确认 的 DT TPDU 的 序号 未 变 ， 但 具有 一 个 更 高 的 子 序号 。 


口 它 所 确认 的 DT TPDU 的 序号 未 变 ， 所 携带 的 子 序号 也 未 变 ， 但 
具有 一 个 更 大 的 信用 量 CDT 。 


若 同 时 收 到 若干 个 AK TPDU， 则 按 YR-TU-NR 字 段 从 小 到 大 进行 
处 理 。 当 “YR-TU-NR” 字 段 值 相 同时 ， 按 “ 子 序号 ”字段 值 从 小 到 大 进 
行 处 理 。 如 果 “ 子 序号 ”字段 值 也 相同 ， 则 按 信用 量 CDT 字 段 值 从 小 到 
大 进行 处 理 。 


3.ED IPDU 


ED TPDU 只 能 选择 TP1~TP4 类 型 传输 协议 进行 传输 ， 它 与 DT 
TPDU 一 样 也 分 为 在 建立 连接 时 选择 了 TP2~TP4 传 输 类 型 和 未 选择 
TP2~TP4 传 输 类 型 两 种 情况 ， 对 应 的 格式 也 与 DTTPDU 的 两 种 情况 下 
的 格式 完全 一 样 〈 分 别 参见 图 10-9 和 图 10-10) ， 不 同 的 只 是 其 中 
的 “代码 ” 值 为 0001 (建立 传输 连接 时 未 选择 TP2~TP4 协 议 类 型 时 ) 或 
0001 0000 (建立 传输 连接 时 已 选择 TP2~TP4 协 议 类 型 时 ) 。 


对 ED TPDU 的 流程 控制 比较 简单， 因为 在 任何 时 刻 仅 允 许 一 个 未 
被 确认 的 ED TPDU 在 通信 途中 ， 也 就 是 说 ， 发 送 窗口 大 小 为 1。 在 接 
收 端 ， 即 使 当 正常 数据 的 信用 量 的 大 小 为 0 时 也 必须 接受 收 到 的 ED 


TPDU。 当 收 到 重复 的 ED 时 也 要 发 回 确 认 ， 不 过 要 将 重复 的 ED TPDU 


丢弃 。 


一 个 ED TPDU 应 该 保证 不 能 比 在 它 以 后 发 出 的 正常 数据 DT TPDU 
更 述 地 交付 给 接收 端的 传输 用 户 。 为 了 做 到 这 一 点 ，TP4 规 定 传输 实 
体 将 传输 用 户 发 过 来 的 并 已 收 到 的 正常 DT TPDU 和 暂停 发 送 ， 而 先 发 送 
加 速 数据 。 只 有 在 加 速 数 据 确认 (EA TPDU) 收 到 后 才能 再 发 送 正常 
数据 。 


4.EA TPDU 


EA TPDU 也 只 能 选择 TP1~TP4 类 型 传输 协议 进行 传输 ， 它 与 AK 
TPDU 一 样 也 分 正常 和 扩展 两 种 情况 ， 对 应 的 格式 也 与 AK TPDU 的 两 
种 情况 下 的 格式 基本 一 样 ， 分 别 如 图 10-13 和 图 10-14 所 示 。 对 比 图 10- 
11 和 图 10-12 可 见 ，EA TPDU 中 只 是 少 了 CDT 字 段 (因为 加 速 数 据 的 发 
送 是 不 按 TPDU 顺 序号 发 送 的 ， 有 加 速 数据 就 立即 发 送 ， 是 数据 传输 
过 程 中 的 少数 特例 ) ， 同 时 , “代码 ”字段 均 为 0010 0000， 代 表 是 EA 
TPDU。 扩 展 EA TPDU 格 式 中 也 没有 “序列 号 "和 “EOT” 这 两 部 分 ， 这 也 
是 因为 加 速 数据 是 不 需要 根据 TPDU 序 列 号 来 发 送 的 。 其 他 字段 与 AK 
TPDU 中 的 对 应 字段 作用 相同 。 


0 7 位 


Ll 
目的 参考 ( 16 位 ) 


你 的 TPDU 序 列 号 


可 变 部 分 


10-13 正常 情况 下 的 EA TPDU 格 式 


0 7 位 
代码 


目的 参考 ( 16 位 ) 


你 的 TPDU 序 列 号 (32 人 ) 


可 变 部 分 


10-14 ”扩展 情况 下 的 EA TPDU 格 式 


说 明 数据 发 送 的 初始 信用 量 分 配 规则 : 对 于 流向 目的 端的 数 
据 ， 其 初始 信用 量 分 配 由 CC TPDU 提 供 ;， 而 对 于 流向 源 端 的 数据 ， 其 
初始 信用 量 分 配 是 由 CR TPDU 提 供 的 。 在 以 后 的 数据 发 送 中 ， 信 用 量 
分 配 的 大 小 是 通过 AK TPDU 来 分 配 的 。 


10.1.7 ”传输 连接 释放 阶段 的 TPDU 


在 连接 释放 阶段 主要 的 TPDU 分 为 DR TPDU 和 DC TPDU 两 种 ， 前 
者 是 断 开 连 接 请 求 的 TPDU， 后 者 是 断 开 连接 确认 的 TPDU 。 


DR TPDU 和 DC TPDU 的 格式 分 别 如 图 10-15 和 图 10-16 所 示 。 其 中 
DR TPDU“ 代 码 ” 字 段 的 值 为 1000 0000，DC TPDU“ 代 码 ” 字 段 的 值 为 
1100 0000。DR TPDU 中 的 “原因 ?字段 会 显示 断 开 连接 的 原因 ， 其 他 字 
段 参 见 前 面 对 应 小 节 的 说 明 。 


7 位 


10-15 ”DR TPDU 格 式 


0 7 位 


目的 参考 (16 位 ) 


10-16 DC TPDU 格 式 


10.1.8 ”传输 服务 原 语 


“服务 原 语 ” (service primitive) 是 服务 功能 实现 的 具体 过 程 描 述 ， 
也 束 是 要 完成 一 项 服务 ， 必 须要 经 过 哪些 主要 步 驴 。 一 个 服务 通 单 由 
一 组 原 语 操 作 来 拓 述 ， 用 户 进程 通过 这 些 原 语 操作 可 以 访问 该 服务 。 
这 些 原 语 告诉 该 服务 执行 某 个 动作 ， 或 者 将 某 个 实体 所 执行 的 动作 报 
告 给 用 户 。 如 有 果 协 议 栈 位 于 操作 系统 中 〈 大 多 数 情况 是 这 样 的 ) ， 则 


这 些 服务 原 语 通 音 是 一 些 系统 调用 。 这 些 系统 调用 会 进入 到 内 核 模 
式 ， 然 后 在 内 核 模 式 中 控制 该 机 器 ， 让 操作 系统 发 送 必 要 的 分 组 。 到 
奈 哪 些 原 语 可 以 使 用 则 取决 于 所 提供 的 服务 ， 针 对 面向 连接 的 服务 的 
原 语 与 针对 无 连接 的 服务 的 原 语 十 不 同 的 。 在 OSVRM 体 系 结构 中 ， 服 
务 原 语 每 层 都 有 ， 并 不 只 是 传输 层 才 有 。 


传输 服务 类 似 于 网 络 服务 ， 但 两 着 存在 显 考 的 区 别 。 网 络 服务 倾 
向 于 将 实际 网 络 提供 的 服务 模型 化 ， 由 于 网 络 内 部 问题 ， 实 际 的 网 络 
可 能 会 丢失 数据 分 组 ， 所 以 网 络 服务 并 不 十 分 可 靠 。 相反 ， 面 同 连 拉 
的 传输 服务 则 是 可 车 的 ， 虽 然 实 际 的 传输 服务 并 非 轻 无 错误 ， 但 在 不 
可 靠 的 网 络 服务 之 上 提供 可 徘 的 传输 服务 正 是 传输 层 要 实现 的 目标 。 


1. 一 个 简单 的 传输 服务 原 语 模型 


在 正式 介绍 传输 层 服 务 原 语 前 ， 先 来 通过 一 个 最 基本 、 最 简单 的 
传输 服务 原 语 模型 来 理解 传输 服务 原 语 的 侣 义 。 这 个 简单 的 传输 服务 
模型 仅 包 括 : 监听 (Listen) 、 连 接 (Connect) 、 发 送 (Send) 、 接 收 
(Receive) 、 断 开 连 接 (Disconnect) 。 它 们 代表 了 一 个 C/S 模 式 的 数 
据 传 输 服 务 基本 过 程 ， 这 也 是 面向 连接 的 传输 层 服 务 的 5 个 基本 过 程 。 
这 5 个 基本 服务 原 语 所 发 送 的 TPDU 和 代表 的 含义 如 表 10-3 所 示 。 


表 10-3 5 种 基本 的 传输 服务 原 语 


服务 原 语 可 发 送 的 TPDU 具体 含义 

Listen 处 于 阻塞 状态 ， 直 到 有 某 个 进程 试图 与 它 建 立 连 接 为 上 
Connect E 动 请 求 建立 一 个 连接 

Send 发 送 用 户 数 据 DT TPDU 

Receive 处 于 阻塞 状态 ， 直 到 收 到 一 个 DT TPDU 为 止 
Disconnect 请 求 释 放 一 个 已 建立 的 连接 


现 假 设 一 台 服 务 右 将 被 多 个 客户 闪 访 问 ， 这 些 基本 传输 服务 原 语 
的 应 用 流程 如 下 (从 最 初 状态 开始 ) 。 图 10-17 给 出 了 全 用 这 些 简单 传 
输 服务 原 语 来 建立 和 释放 连接 的 状态 图 。 每 一 个 状态 的 出 现 都 是 一 种 
事件 触发 ， 或 者 是 由 本 地 的 传输 用 户 执行 了 一 个 原 语 ， 或 者 是 接收 到 
了 一 个 TPDU 分 组 。 不 过 要 注意 ， 此 处 为 了 简单 起 见 ， 假 设 了 每 一 个 
TPDU 都 和 单独 确认 的 ， 而 且 也 采用 了 对 称 释 放 模 型 ， 由 客户 爷 释放 和 连 
接 。 图 10-17 中 实 线 箭 头 显示 了 客户 端的 状态 序列 ， 而 虚线 箭头 则 显示 
了 服务 器 的 状态 序列 。 


执行 Connecet 厚 话 


主动 建立 连接 


收 到 CC TPDU 


主动 断 开 连接 


ed 


图 10-17 一 个 简单 传输 服务 原 语 的 应 用 示例 


1) 一 开始 ， 服 务 器 调用 Listen 原 语 ， 使 其 处 于 监听 状态 ， 直 到 有 
客户 来 请 求 连接 。 
2) 当 一 个 客户 希望 与 该 服务 器 进行 会 话 时 ， 它 调用 Connect 原 语 ， 


癌 服务 器 发 送 一 个 请 求 建 立 传输 连接 的 CR TPDU 。 


3) 当 该 CR TPDU 到 达 服 务 器 时 ， 服 务 右 传输 服务 实体 执行 状态 检 
查 ， 看 服务 此 是 否 正 处 于 监听 状态 。 如 果 是 ， 则 解除 监听 ， 并 癌 客 户 


端 返回 一 条 确认 连接 请 求 的 CC TPDU 。 


4) 在 这 个 CC TPDU 到 达 客 户 端 后 ， 客 户 端 获 知 服务 器 同意 建立 传 
输 连 接 了 ， 随 后 便 通 知客 户 端 应 用 进程 开始 建立 传输 连接 。 


5) 传输 连接 建议 好 后 ， 就 可 以 正式 发 送 DTTPDU 了 。 任 何 一 方 都 
可 以 调用 Receive 原 语 ， 以 等 待 另 一 方 调用 Send 原 语 ， 发 送 数据 。 当 一 
方 接收 到 另 一 方 发 来 的 DT TPDU 时 ， 接 收 端 会 发 送 一 个 数据 接收 确认 
的 DATPDU 。 


6) 当 不 再 需要 一 个 连接 时 ， 传 输 用 户 必 须 将 它 释 放 ， 以 便 使 两 个 
传输 实体 内 部 的 缓存 空间 有 机 会 被 重新 使 用 。 


释放 连接 有 两 种 形式 : 对 称 释放 和 非 对 称 释 放 。 在 非 对 称 释放 
中 ， 任 何 一 方 都 可 以 调用 Disconnect 原 语 ， 在 本 端 传输 实体 向 对 端 发 送 
一 个 DR TPDU 后 双 辐 传输 连接 都 将 被 释放 。 在 对 称 释放 中 ， 连 接 的 两 
个 方向 彼此 独立 ， 每 个 方向 需要 单独 被 释放 。 当 一 方 调用 Disconnect 原 
语 时 ， 意 味 着 它 不 再 需要 发 送 数据 了 ， 但 它 仍 然 布 望 能 接收 对 方 发 过 
来 的 数据 。 在 这 种 方式 中 ， 只 有 在 双方 都 调用 了 Disconnect 原 语 ， 各 目 
癌 对 方 发 送 DR TPDU 后 一 个 传输 连接 才 可 能 被 真正 释放 出 来 。 


2.ISO 规 范 中 的 传输 服务 原 语 


在 OSIURM 体 系 结构 的 ISO 规范 中 ， 各 层 服务 原 语 分 为 以 下 4 种 类 


昱 


口 请 求 (request) : 用 户 利用 它 要 求 服 务 提 供 者 提供 某 项 服务 ， 如 
建立 连接 或 发 送 数据 等 。 


口 指示 (indication) : 服务 提供 者 执行 请 求 原 语 后 ， 用 指示 原 语 
通知 本 端 用 户 实体 ， 告 知 有 人 想 要 与 之 建立 连接 或 发 送 数据 等 。 


口 响应 response) : 收 到 指示 原 语 后 ， 利 用 响应 原 语 癌 对 方 做 出 
反应 ， 如 同意 或 不 同意 建立 连接 等 。 


口 确认 (confirm) : 请 求 方 可 以 通过 接收 确认 原 语 来 获悉 对 方 是 


否 同意 接受 请 求 。 


在 这 4 个 服务 原 语 中 ，request 和 response 由 请 求 服务 用 户 调用 ， 而 
indication 和 confirm 则 是 由 服务 提供 者 调用 。 各 类 服务 原 语 均 可 以 携 市 
参数 ， 如 请 求 原 语 的 参数 可 能 指明 它 要 与 哪 台 机 器 连接 ， 需 要 什么 服 
务 类 别 等 ， 指 示 原 语 的 参数 可 能 包含 呼叫 者 的 标识 、 需 要 服务 的 类 别 
等 ;响应 原 语 的 参数 可 能 包括 同意 或 不 同意 连接 的 关键 字 ; 在 确认 原 
语 中 ， 则 可 能 对 某 些 参数 给 出 协商 值 ， 比 如 最 大 数据 吞吐 量 等 。 


党 


在 OSURM 体 系 结构 的 传输 层 中 ， 主 要 包括 10 种 传输 服务 原 语 ， 分 
布 在 传输 连接 建立 、 数 据 发 送 和 传输 连接 断 开 这 3 个 主要 阶段 中 。 其 


中 ， 在 传输 连接 建立 阶段 所 需 的 4 个 服务 原 语 说 明 如 下 (小 圆 点 后 面部 
分 代表 对 应 的 传输 服务 原 语 类 型 ， 下 同 ) 。 


DT_CONNECTrequest: 传输 连接 请 求 原 语 。 容 户 端 通过 CR 
TPDU 向 服务 器 请 求 ， 让 对 方 建立 一 条 传输 连接 。 


DT_CONNECT'indication: 传输 连接 指示 原 语 。 服 务 器 向 目 己 的 
用 户 实体 〈 用 户 应 用 进程 ) 指示 有 客户 要 求 与 自己 建立 传输 连接 。 


DT_CONNECT.response: 传输 连接 啊 应 原 语 。 服 务 器 通过 CC 
TPDU 辐 客户 端 发 送 一 条 传输 连接 建立 响应 。 


DT_CONNECT.confirm: 传输 连接 确认 原 语 。 客 户 端 收 到 服务 硕 
的 传输 连接 响应 后 ， 向 本 端 用 户 实 体 〈 用 户 应 用 进程 ) 确认 服务 器 是 


否 已 接受 连接 请 求 。 


在 数据 传送 阶段 所 需 的 服务 原 语 如 下 。 


DT_DATIA.request: 数据 传输 请 求 原 语 。 加 对方 提 出 发 送 数据 请 


DT_DATA.indication: 数据 传输 指示 原 语 。 辐 本 端 用 户 实 体 指示 有 
人 要 向 自己 发 送 数据 。 


口 T_EXPEDITED_DATA.request 加 速 数据 传输 请 求 原 语 。 向 对 方 
提出 发 送 回 还 数据 请 求 。 


DT_EXPEDITED_ DATA.indication: 加 速 数 据 传输 指示 原 语 。 向 本 
端 用 户 实体 指示 有 人 要 回 目 己 发 送 加 速 数据 。 


在 传输 连接 释放 阶段 所 需 的 服务 原 语 如 下 。 


DT_DISCONNECT.request: 释放 传输 连接 请 求 原 语 。 回 对 方 提供 
释放 传输 连接 请 求 。 


DT_DISCONNECT.indication: 释放 传输 连接 指示 原 语 。 回 本 端 用 
户 实 体 指 示 对 端 要 释放 传输 和 连接， 以 便 做 出 相应 的 处 理 。 


以 上 10 个 传输 服务 原 语 的 综合 比较 如 表 10-4 所 示 。 


表 10-4 10 个 主要 传输 服务 原 语 综合 比较 


阶段 服 务 使 用 的 服务 原 语 参 数 
被 叫 地 址 、 主 叫 地 址 、 加 速 数据 选择 、 服 务 
T_CONNECT.indication 质量 、 传 输 服务 用 户 数据 
建立 传输 连接 ee 
T_CONNECT.response 服务 质量 、 响 应 地 址 、 加 速 数据 选择 、 传 输 
T_CONNECT.confirm 服务 用 户 数据 
、 T_DATA .request 、 
正常 数据 传送 ”和 po 传送 服务 用 户 数 据 
. T DATA.indication 
数据 传送 
T_EXPEDITED DATA.request 
加 速 数据 传送 一 一 -一 一 一 传送 服务 用 户 数据 
T_EXPEDITED _ DAIA.indication 
T_DISCONNECT.request 传送 服务 用 户 数据 
T_DISCONNECT.indication 拆除 连接 原因 、 传 送 服务 用 户 数据 


连接 释放 ”| 释放 传输 连接 


表 10-4 中 ,“ 主 叫 地 址 ”参数 是 指 请 求 传输 连接 的 TSAP 地 址 ; “被 叫 
地 址 ”参数 是 指 与 之 建立 传输 连接 的 TSAP 地 址 ;“ 了 响应 地 址 ”参数 等 于 被 
叫 地 址 参数 ; “加速 数据 选择 ”参数 是 指 在 传输 连接 上 是 否 可 使 用 加 速 
数据 服务 (如 果 声 明 没 有 这 项 服务 ， 它 就 不 能 在 传输 连接 上 使 
用 ) ; “传输 服务 用 户 数据 ”参数 是 在 传输 用 户 之 间 传 送 的 传输 服务 用 
户 数据 ， 传 输 服务 提供 者 不 进行 修改 ， 其 长 度 为 1~32 字 节 ; “服务 质 
量 * 参 数 包括 传输 服务 用 户 的 一 些 要 求 ， 即 QoS 参 数 。 


无 连接 的 传输 服务 只 有 两 个 原 语 ， 如 表 10-5 所 示 。 


表 10-5 无 连接 传输 服务 原 语 


原 语 参 数 
T_UNIT_DATA .request E 岂 地 址 、 被 叫 地 址 、 服 务 质量 、 传 送 服务 用 户 数据 
T_UNIT_DATA.indication 匡 叫 地 址 、 被 叫 地 址 、 服 务 质 量 、 传 送 服务 用 户 数据 


可 用 如 图 10-18 所 示 的 状态 转移 图 来 说 明 OSVRM 体 系 结构 中 定义 的 
面向 连接 传输 服务 在 连接 建立 和 连接 释放 两 个 阶段 的 服务 原 语 的 使 用 
情况 。 状 态 1 是 空 几 状态 ， 表 示 没 有 传输 连接 。 每 次 连接 的 建立 都 从 这 
一 状态 开始 ， 而 在 连接 释放 后 总 是 再 回 到 这 个 空 闪 状态。 状态 2 和 状态 
3 都 属于 连接 建立 阶段 。 状 态 4 是 数据 传送 就 绪 阶 段 ， 实 际 上 也 就 进入 
了 数据 传输 阶段 ， 调 用 相应 的 原 语 后 就 可 以 进行 数据 传输 了 。 无 论 在 
连接 建立 阶段 还 是 在 数据 传送 阶段 ， 都 可 以 通过 连接 释放 原 语 返 回 到 
原始 的 空间 状态 。 图 10-18 的 状态 转移 示意 图 指示 在 一 个 传输 连接 的 一 
个 端点 上 可 能 发 生 的 状态 序列 ， 箭 头 旁边 注 明 的 是 对 应 状态 转移 时 所 


需 调 用 的 相关 原 语 ， 在 这 些 原 语 的 交互 作用 下 ， 状 态 沿 箭头 转移 到 下 
= 本 


T_DISCONNET.request 
T_DISCONNECT.indication 


T_CONNECT 


.Tequest 


T_DISCONNECT.request 
T_DISCONNECT.indication 


T_CONNECT. 


indication 


3. 等 待 
连接 请 求 


T_DISCONNECT. 


T_DISCONNECT 


.indication 


T_CONNECT.confirm 


T_CONNECT.response 


4. 数据 
传输 就 绪 


图 10-18 传输 连接 建立 和 释放 阶段 的 一 端 主机 状态 转移 示意 图 


10.2 ”传输 层 服务 功能 


从 上 文 可 知 ， 传 输 层 要 完成 问 到 端的 透明 数据 传输 ， 至 少 要 分 为 
两 个 步骤 : 一 是 虚拟 传输 连接 的 建立 (此 处 仍 仅 针对 面向 连接 的 传输 
层 协议 ) ， 二 是 源 端 用 户 数 据 沿 着 传输 连接 传送 到 目的 端 。 在 整个 数 
据 传 输 过 程 中 ， 传 输 层 服务 需要 完成 以 下 8 个 方面 的 基本 功能 : 传输 层 
寻 址 、 传 输 连 接 建 立 、 数 据 传输 、 传 输 连 接 释放 、 流量 控制 、 拥 塞 控 
制 、 多 路 复 用 和 解 复 用 、 般 省 恢复 。 这 些 是 本 章 的 重点 与 难点 ， 硕 望 
读者 着 重 理解 这 些 功 能 的 实现 原理 。 


10.2.1 ”传输 层 寻 址 方案 


在 本 章 前 面 就 已 说 到 ， 虽 然 网 络 层 把 数据 分 组 从 源 主 机 传送 到 了 
目的 主机 ， 但 是 这 并 不 代表 数据 的 传输 过 程 束 全 部 完成 了 ， 因 为 数据 
分 组 还 没有 真正 地 交付 给 相应 的 应 用 进程 ， 此 时 应 用 进程 才 是 数据 通 
信 主 体 。 而 我 们 又 知道 ， 同 一 时 间 的 通信 双方 可 能 存在 许多 并 发 应 用 
进程 ， 那 么 源 端 来 的 数据 分 组 该 区 给 哪个 应 用 进程 呢 ? 这 就 涉及 传输 
层 的 寻 址 问题 了 。 在 本 章 前 面 已 介绍 了 TSAP (传输 服务 访问 点 ) ， 它 
代表 的 是 一 个 传输 层 端 口 ， 因 为 传输 层 是 以 一 个 闪 对 应 一 个 应 用 进程 
来 表示 的 。 


应 用 进程 (包括 客户 端 和 服务 器 ) 可 以 将 目 己 关 联 到 一 个 TSAP 
上 ， 以 便 与 远程 的 TSAP 建 立 连接 。 但 是 我 们 知道 ， 只 有 少数 常见 的 服 
务 (如 WWW、FTP、POP、SMTP、DNS、DHCP 等 ) 是 固定 分 配 了 
TSAP 地 址 一 一 端口 的 ， 绝 大 多 数 服 务 并 没有 与 固定 的 端口 进行 绑 定 ， 
所 以 这 些 服务 的 发 送 端 就 需要 接收 端 对 应 用 户 进程 关联 的 TSAP 地 址 。 
那么 ， 发 送 主机 的 用 户 进程 如 何 知 道 接收 主机 对 应 用 户 进程 关联 的 
TSAP 地 址 呢 ? 下 文 将 进行 介绍 。 另 外 ， 在 一 台 服 务 磺 上 有 大 量 潜在 的 
服务 进程 ， 但 是 大 多 数 服务 进程 又 很 少 使 用 ， 那 么 让 每 个 服务 进程 都 
主动 、 持 续 地 监听 一 个 TSAP 地 址 显然 是 非常 不 明和 养 的 ， 也 浪费 了 大 量 
的 服务 器 资源 。 


1. 进 程 服务 器 的 TSAP 地 址 分 配方 案 


为 了 解决 以 上 问题 ， 提 出 了 一 种 更 好 的 方案 ， 那 束 是 “进程 服务 
器 "方案 ， 它 是 “初始 连接 协议 ” (initial connection protocol) 方案 的 一 
种 。 它 先 由 进程 服务 器 为 各 应 用 进程 集中 建立 初始 传输 连接 ， 然 后 再 
转 给 对 应 的 服务 进行 正 却 的 传输 和 连接。 进程 服务 闫 的 TSAP 地 址 分 配方 
案 的 做 法 不 是 让 每 一 个 对 外 提供 的 服务 都 在 一 个 特定 的 端口 上 监听 ， 
而 是 使 用 一 个 特殊 的 进程 服务 右 (process server) 来 集中 为 那些 较 少 使 
用 的 服务 提供 监听 代理 功能 。 它 可 以 同时 监听 一 组 端口 ， 以 等 每 外 来 
的 连 毛 请 求 。 每 个 服务 的 潜在 用 户 忌 古 从 一 个 Connect 请 求 开 始 ， 在 


Connect 请 求 中 指定 了 这 些 用 户 想 要 的 服务 的 TSAP 地 址 。 进 程 服 务 器 为 
用 户 进程 分 配 TSAP 地 址 的 基本 流程 如 图 10-19 所 示 ， 有 具体 解释 如 下 。 


公开 /固定 的 TSAP 
客户 端 


服务 天 


2. 装载 进程 1 
分 配 TSAP 


< 省 


初始 连接 协议 


图 。10-19 ”进程 服务 器 为 用 户 进程 分 配 TSAP 地 址 的 基本 流程 


1) 用 户 向 服务 器 发 送 一 个 传输 连接 请 求 ， 如 果 没 有 专门 的 服务 器 
主 等 待 ， 则 会 得 到 一 个 与 “进程 服务 做 ”之 间 的 连接 。 


2) 进程 服务 器 接 到 了 用 户 的 传输 连接 请 求 后 ， 装 载 对 应 的 用 户 进 
程 ， 局 动 与 该 请 求 对 应 的 服务 。 


3) 进程 服务 器 为 该 用 户 进 程 分 配 一 个 临时 的 TSAP 地 址 ， 这 样 用 
户 与 对 应 的 服务 凑 进 行 初始 连接 ， 人 允许 对 应 的 服务 继承 进程 服务 大 与 
用 户 之 间 已 有 的 连接 ， 然 后 对 应 的 服务 执行 用 户 请 求 的 工作 ， 而 进程 
服务 器 则 继续 监听 新 的 请 求 。 


例如 ， 某 公司 有 多 个 产品 营销 部 门 ， 每 个 部 门 设立 了 一 个 专门 的 
售后 服务 热线 电话 。 但 其 中 有 些 部 门 的 热线 电话 比较 忙 ， 经 名 有 用 户 
打 电 话 咨询 或 投诉 ， 而 有 些 部 门 的 热线 电话 打 进 来 的 人 比较 少 。 这 
时 ， 如 琳 仍 为 每 个 部 门 专 门 安 排 一 个 人 负责 热线 电话 ， 显 然 对 于 那些 
用 户 参 与 比较 少 的 热线 电话 来 说 是 一 种 浪费 。 这 时 我 们 肯定 会 想到 ， 
把 这 些 用 户 参与 比较 少 的 部 门 的 热线 电话 用 一 个 总 线 电话 来 转 接 ， 只 
需要 一 个 专门 的 接线 员 来 管理 总 机 即 可 。 当 有 人 打 这 个 总 线 电 话 时 ， 
总 机 接线员 询问 所 咨询 的 内 容 ， 然 后 再 把 电话 转 接 到 对 应 的 部 门 分 
机 ， 由 对 应 的 部 门 接线 员 进 行 处 理 ， 总 机 接线 员 又 继续 等 待 下 一 个 用 
户 电话 ， 而 这 些 部 门 的 热线 电话 接线 员 平 时 可 以 进行 其 他 工作 ， 不 必 
总 在 那里 等 每 用 户 的 来 电 ， 市 省 了 人 力 资 源 。 


2. 名 称 服务 器 的 TSAP 地 址 分 配方 案 


虽然 以 上 介绍 的 “初始 连接 协议 ”在 大 多 数 情况 下 都 可 以 满足 需 
求 ， 也 可 以 工作 得 很 好 ， 但 是 在 一 些 特殊 情况 下 还 是 有 些 服务 的 运行 
必须 独立 于 进程 服务 器 。 如 一 个 文件 服务 器 需要 在 特殊 的 硬件 上 运 
行 ， 不 能 当 用 户 要 与 它 通话 的 时 候 才 临时 创建 连接 。 殊 像 前 面 所 说 的 
那些 用 户 参 与 比较 多 的 部 门 热 线 电话 ， 如 果 仍 由 总 线 来 转 接 ， 总 线 接 
线 员 可 能 忙 不 过 来 ,或 者 由 于 电话 过 多 而 使 电话 线路 总 处 于 占线 状态 
而 延误 了 处 理 时 间 。 这 里 还 有 一 个 问题 ， 对 于 那些 知名 的 服务 ， 在 用 
户主 机 应 用 进程 中 仍然 非常 多 ,但 也 并 不 是 所 有 的 应 用 进程 总 那么 繁 


忙 ， 如 有 的 主机 可 能 仅 担当 少数 儿 种 服务 部 角色 ， 而 绝 大 多 数 知 名 服 
务 在 这 人 台 主 机 中 并 没有 实际 上 被 提供 。 因 此 ， 此 时 仍 需要 对 这 些 知 名 
服务 提供 集中 的 管理 ， 以 减少 服务 器 资源 的 痕 费 。 


为 了 解决 上 述 问 题 ， 又 推出 了 一 种 新 的 方案 一 一 “名 称 服务 

器 ” (name server) ， 有 了 时 也 称 “ 目 录 服 务 器 ”(directory server) ， 也 就 
是 我 们 通常 所 说 的 DNS 服 务 器 。 它 也 是 “初始 连接 协议 ”方案 的 一 种 。 

名 称 服务 器 总 是 在 监听 一 个 特定 的 知名 服务 的 端口 (也 就 是 我 们 通常 
所 说 的 “常规 端口 5” 。 在 这 种 方案 中 ， 为 了 找到 与 给 定 的 服务 名 字 相 
对 应 的 TSAP 地 址 (端口 ) ， 用 户 需 要 与 名 称 服务 器 建立 一 个 连接 ， 然 
后 用 户 发 送 一 条 消息 指定 它 想 要 的 服务 名 字 ， 名 称 服务 器 则 发 回 相 应 
的 TSAP 地 址 。 随 后 ， 用 户 将 它 与 名 称 服 务 器 之 间 的 连接 释放 ， 再 与 期 
望 的 服务 建立 一 个 新 的 连接 。 名 称 服务 器 为 用 户 进 程 分 配 TSAP 地 址 的 
整体 流程 与 上 面 介绍 的 进程 服务 器 为 用 户 进程 分 配 TSAP 地 址 的 流程 类 
似 ， 如 图 10-20 所 示 ， 只 是 名 称 服务 器 的 效率 更 高 而 已 。 
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图 10-20 名称 服 务 器 为 用 户 进程 分 配 TSAP 地 址 的 基本 流程 


名 称 服务 事 之 所 以 知道 这 些 知名 服务 的 TSAP 地 址 ， 古 因为 在 一 个 
新 的 服务 被 创建 时 必须 向 名 称 服务 器 注册 ， 并 把 它 的 服务 名 字 和 TSAP 
地 址 告诉 名 称 服 务 器 。 名 称 服务 器 将 把 这 份 信息 记录 到 它 的 内 部 数据 
库 中 ， 以 后 当 用 户 碍 询 时 就 知道 了 。 例 如 ， 在 配置 DNS 服务 器 时 ， 
把 这 台 机 右上 所 配置 的 各 服务 右 角 色 的 对 应 服务 记 杂 添 加 a 到 DNS 服 务 
器 中 ， 这 些 记录 中 会 记录 对 应 的 服务 器 名 称 、 所 用 端口 信息 。 


10.2.2 ”传输 连接 建立 


通过 本 章 前 面 介绍 的 内 容 可 知 ， 表 面 上 看 起 来 传输 连接 的 建立 过 
程 很 简单 ， 用 户 端 只 需 调用 T_CONNECT.request 和 
T_CONNECT.confirm 原 语 ， 服 务 响 端 只 需 调用 T_CONNECTindication 
和 T_CONNECT.response 原 语 ， 但 其 实 传输 连接 的 建立 非常 烦 锁 ， 因 为 
它 受 到 网 络 延 民 、 子 网 分 组 存储 、 重 复 分 组 接收 等 诸多 因素 影响 。 下 
面 先 看 一 下 正常 情况 下 基本 的 传输 连接 过 程 。 


1. 正 常 传输 连接 的 建立 


在 正常 情况 下 ， 传 输 连 接 的 建立 过 程 比 较 简 单 ， 所 用 到 的 传输 服 
务 原 语 是 上 文 介绍 的 T_CONNECT.request、T_CONNECT.indication 、 
T_CONNECT.response、T_CONNECT.confirm， 所 用 到 的 TPDU 主 要 有 
CR TPDU 和 CC TPDU 两 个 。 传 输 连 接 建 立 的 基本 过 程 如 图 10-21 所 示 ， 
描述 如 下 。 
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图 10-21 传输 连接 建立 的 基本 流程 


1) 客户 端 主机 A 用 户 实体 中 的 对 应 用 户 进程 调用 传输 层 的 
T_CONNECT.request 服 务 原 语 ， 由 所 使 用 的 传输 层 协 议 回 服务 紫 端 主 
机 B 发 送 一 条 CR (连接 请 求 ) TPDU， 请 求 建立 一 条 传输 连接 。 


说 明 在 OSVRM 体 系 结构 中 ， 用 户 实体 位 于 “会 话 层 ”中 ， 而 在 
TCP/IP 体 系 结构 中 ， 用 户 实体 位 于 “应 用 层 * 中 ， 下 同 。 


2) 主机 B 传 输 层 在 收 到 来 自主 机 A 的 这 条 连接 请 求 TPDU 后 ， 通 过 
调用 T_CONNECT.indication 服 务 原 语 ， 告 诉 自己 的 用 户 实体 中 的 对 应 
用 户 进 程 : 有 用 户 想 与 自己 建立 传输 连接 。 


如 果 传 输 服务 提供 者 (主机 B) 提出 降低 服务 质量 (如 较 小 的 否 吐 
量 、 较 长 的 时 延 、 较 高 的 差错 率 、 较 低 的 优先 级 等 ) 要 求 ， 那 么 这 时 


一 些 新 的 参数 会 出 现在 T_CONNECT.indication 原 语 中 。 


3) 如 果 接 受 连接 请 求 ， 则 主机 B 用 户 实体 调用 传输 层 的 
T_CONNECT.response 服 务 原 语 ， 然 后 通过 传输 层 协 议 癌 主机 A 发 送 一 
条 CC (连接 确认 ) TPDU 。 


如 果 传 输 服务 用 户 (主机 A) 提出 降低 服务 质量 要 求 ， 其 参数 将 出 
现在 T_CONNECT.response 原 语 中 。 最 后 ， 通 过 下 一 步 改 送 的 CC TPDU 
将 参数 返回 到 源 端 的 传输 用 户 。 


4) 主机 A 在 收 到 来 自主 机 B 的 CC TPDU 后 ， 通 过 调用 传输 层 的 
T_CONNECT.confirm 服 务 原 语 ， 回 目 己 的 用 户 实 体 中 的 源 用 户 进程 确 
认 连 接 已 建立 ， 正 式 进入 数据 发 送 阶段 。 


从 以 上 的 步骤 可 以 看 出 ， 好 像 传输 连接 的 建立 过 程 很 简单 ， 但 实 
际 上 ， 传 输 连 接 的 建立 远 不 是 这 样 的 ， 甚 至 可 以 用 非常 烦 锁 来 形容 ， 
主要 体现 在 因 网 络 拥塞 而 出 现 多 次 连接 ， 或 因 网 络 中 存在 延迟 的 重复 
分 组 而 造成 重复 连接 。 


2. 传 输 连接 拒绝 


首先 要 注意 的 是 ,“ 传 输 连接 拒绝 ”不 是 “传输 连接 释放 ”， 它 是 传输 
连接 请 求 在 建立 连接 过 程 中 被 对 端 拒绝 ， 此 时 传输 连接 根本 还 没 建 立 
起 来 ， 即 在 建立 过 程 中 就 中 断 了 。 


在 以 上 “传输 连接 建立 ”过 程 中 的 第 3 步 ， 如 果 连 接 的 目的 主机 B 
(服务 提供 者 ) 的 传输 层 可 能 因 源 端的 服务 质量 太 差 ， 或 者 自己 的 线 
路 很 忙 而 要 拒绝 主机 A (服务 请 求 者 ) 的 传输 连接 请 求 ， 这 时 就 可 以 通 

过 发 送 RJTPDU 来 实现 了 ， 具 体 过 程 如 下 。 


1) 当 来 自主 机 A 的 CR TPDU 到 了 主机 B 的 传输 层 后 ， 通 过 调用 自 
己 传 输 层 的 T_CONNECT'indication 原 语 向 对 应 的 用 户 进程 说 明 有 用 户 
需要 与 它 建 立 传输 连接 ， 同 时 会 通过 对 CR TPDU 的 分 析 得 出 源 端 的 服 
务 质量 水 平 。 


2) 如 果 主 机 B 应 用 进程 认为 源 端的 服务 质量 水 平 太 差 ， 或 者 应 用 
层 目 前 “工作 ”实在 太 繁 忙 ， 不 接受 此 次 的 传输 连接 请 求 ， 则 通知 传输 
层 向 主机 A 发 送 RJ TPDU， 表 示 拒 绝 此 次 传输 连接 。 


在 “传输 连接 拒绝 ”过 程 中 的 整个 服务 原 语调 用 和 TPDU 发 送 情况 如 
图 10-22 所 示 ， 与 图 10-21 所 示 的 “传输 连接 建立 ”过 程 相 比 ， 唯 一 的 区 别 
就 是 主机 B 向 主机 A 发 送 的 不 再 是 CC TPDU， 而 是 RJ (拒绝 连接 ) 
TPDU。 当然， 主机 B 的 传输 层 向 自己 的 应 用 层 提交 的 
T_CONNECT.indication 原 语 中 的 内 容 也 会 有 所 不 同 ， 会 表示 出 不 愿意 
接受 连接 的 意愿 ， 尽 管 最 终 决 定 是 否 接受 连接 的 是 应 用 层 的 用 户 进 


程 ， 而 不 是 传输 层 。 
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图 10-22 传输 连接 请 求 拒绝 的 基本 流程 


10.2.3 ”重复 传输 连接 的 解决 方法 


在 传输 连接 建立 过 程 中 ， 除 了 大 多 数 可 以 正常 一 次 连接 成 功 外 ， 
还 可 能 因 各 种 原因 出 现 一 些 非 正 常 连 接 现 象 ， 如 因 网 络 拥塞 而 造成 的 
多 次 连接 ， 或 因子 网 分 组 存储 而 造成 的 重复 连接 等 。 


如 有 果 网 络 非常 拥塞 ， 就 会 导致 传输 连接 建立 过 程 中 所 传输 的 确认 
TPDU 分 组 都 无 法 及 时 回 到 发 送 首 ， 这 样 一 来 ， 传 输 连接 发 起 方 可 能 
需要 进行 多 次 连 毛竹 试 。 网 络 延迟 还 可 能 因为 “存储 -转发 "机制 引起 ， 
守 别 是 在 传输 通信 两 端 途经 的 网 络 比 较 多 时 ， 由 于 各 子 网 的 分 组 存储 
的 问题 ， 导 致 一 些 TPDU 分 组 没有 及 时 到达 ， 最 终 造 成 传输 连接 发 起 
方 会 多 次 重 试 。 但 问题 远 不 是 重 试 这 么 简单 ， 因 为 这 些 延 迟 的 分 组 可 
能 在 过 一 段 时 间 后 到 达 了 ， 于 是 又 会 请 求 建立 新 的 连接 ， 这 束 出 现 了 
重复 连接 的 问题 。 


对 于 重复 的 传输 连接 问题 ， 目 前 还 没有 一 种 特别 有 效 的 解决 方 
法 ， 通 常 是 采取 非 重 复 TSAP、 超 时 连接 表 、 分 组 的 TIL 机 制 和 三 次 握 
手机 制 等 方法 尽量 避免 。 


(1) 非 重复 TSAP 


非 重复 TSAP 方 法 是 系统 为 每 次 连接 赋予 一 个 新 的 TSAP 地 址 ， 当 
连接 被 释放 时 将 此 TSAP 废 弃 。 这 样 一 来 ， 就 不 会 出 现 重 复 连接 的 现 
象 。 但 这 种 解决 方法 不 适用 于 那些 知名 服务 的 连接 ， 因 为 像 WWW、 
FTP、POP 之 类 的 传输 连接 是 固定 使 用 那些 知名 的 端口 进行 的 ， 不 可 
能 每 次 都 变 。 


过 时 连接 表 是 为 每 个 连接 分 配 连接 标识 符 (也 就 是 传输 连接 序列 

号 ) 的 ， 每 新 建 一 个 传输 连接 ， 序 列 号 增加 1， 并 且 存 入 到 每 个 TPDU 

(也 包括 请 求 建 立 连接 的 TPDU) 中 。 当 每 个 连接 被 释放 时 ， 将 此 连 

接 信息 存 入 过 时 连接 表 ， 然 后 在 每 个 新 的 连接 请 求 到 达 时 ， 根 据 标识 

符 核 对 过 时 连接 表 ， 如 果 是 已 过 时 的 序列 号 ， 则 视 为 重复 连接 。 但 这 

种 方法 需要 每 个 传输 实体 无 限期 地 维护 一 张 历史 记录 表 ， 不 适应 突变 
情况 ， 如 机 器 重启 、 系 统 崩 演 等 。 


(3) 分 组 的 TTL 机 制 


分 组 的 TTL 机 制 是 先 定义 和 计数 每 个 分 组 的 生存 时 间 TTL， 如 果 
因 超 时 未 达 目 的 地 ， 则 视 为 陈旧 分 组 ， 将 被 抛弃 。 此 机 制 同 样 也 存在 
一 些 问 题 ， 如 消除 重复 连接 请 求 需要 依赖 子 网 完成 、 网 络 层 分 组 传输 
本 身 的 不 可 靠 性 等 。 


(4) 三 次 握手 机 制 


所 谓 “ 三 次 握手 ?是 指 在 建立 连接 时 ， 发 送 端 发 送 CR TPDU 请 求 建 
立 一 个 连接 (第 一 次 握手 )  ; 接收 端 收 到 CR TPDU 后 发 送 一 个 CC 
TPDU 进 行 应 答 (第 二 次 握手 ，， 在 应 答 分 组 中 宣告 了 自己 的 初始 连 
接 序 列 号 ; 发送 端 收 到 应 答 分 组 后 发 送 第 一 个 DTTPDU， 对 接收 端 初 
始 序 列 号 进行 确认 〈 第 三 次 握手 ) 。 这 样 ， 一 个 连接 才能 建立 起 来 ， 
并 且 双 方 可 以 使 用 不 同 的 起 始 序 号 。 整 个 三 次 握手 过 程 如 图 10-23 所 
示 ， 简 单 描述 如 下 (在 TCP/IP 体 系 结构 中 的 TCP 传 输 连接 的 建立 也 采 
用 “三 次 握手 机 制 ”， 具 体内 容 将 在 本 章 后 面 介 绍 ) 。 


主机 A 主机 B 
CR TPDU 


1 


CC TPDU 
DT TPDU 


10-23 ”正常 情况 下 的 传输 连接 三 次 握手 过 程 


在 正常 情况 下 ， 主 机 A 向 主机 B 发 送 一 个 “ 源 参考 ”为 1 (“目的 参 
考 ” 为 0 的 CR TPDU 请 求 以 建立 连接 ; 主机 B 收 到 CR TPDU 后 发 送 一 


个 “ 源 参考 ?为 j (“目的 参考 ”为 i) CC TPDU 应 答 分 组 ， 对 主机 A 发 来 的 

连接 请 求 进行 确认 ; 主机 A 在 收 到 的 CC TPDU“ 源 参考 ”字段 后 就 获知 

主机 B 的 传输 连接 参考 ， 把 它 作 为 “目的 参考 ”字段 值 发 送 第 一 个 携带 
少量 数据 的 DTTPDU (其 中 包括 了 DT TPDU 的 序列 号 ) ， 同 时 对 主机 
选择 的 初始 连接 序号 进行 确认 。 


其 实 三 次 握手 连接 的 原理 很 简单 ， 就 像 我 们 平时 聊天 一 样 ， 首 先 
是 由 发 起 人 说 “Hello” (打招呼 通常 预示 着 要 向 对 方 说 话 ) ， 当 对 方 听 
到 这 个 招呼 后 ， 如 果 确 认 此 时 可 以 与 发 起 方 聊天 ， 则 也 会 发 出 一 个 招 
呼 “Hello”。 这 里 有 两 重 意义 ， 首 先是 证 明 他 已 听 到 发 起 方 的 招呼 ， 另 
一 方面 也 说 明 目 前 自己 可 以 与 发 起 方 聊 天 。 最 后 ， 发 起 方 在 收 到 对 方 
的 回应 招呼 后 ， 可 以 再 次 选择 ， 如 果 恰 在 此 时 又 有 其 他 事 不 能 与 对 方 
聊天 了 ， 当 然 可 以 放弃 ， 如 果 认 为 条 件 成 熟 ， 则 可 以 说 “OK， 
Begin”( 好 的 ， 开 始 吧 ) ， 接 下 来 就 是 正式 的 聊天 了 。 


在 出 现 延 迟 的 重复 CR TPDU 的 情况 下 ， 在 网 络 中 间 延 迟 发 送 的 一 
个 源 参 考 为 的 重复 CR TPDU 到 达 主 机 B 后 ， 请 求 在 已 释放 的 连接 上 建 
立 连接 ， 主 机 B 发 送 一 个 CC TPDU 应 答 分 组 对 原来 源 参考 为 的 请 求 进 
行 应 答 ， 同 时 在 “ 源 参考 ”字段 中 宣告 自己 的 传输 连接 号 为 j， 主 机 A 通 
过 检查 可 知 主机 B 的 应 答 分 组 中 确认 的 源 参考 为 的 连接 原来 已 经 确 
认 ， 便 认为 该 应 答 是 过 时 的 ， 并 疝 主机 B 发 送 一 个 RJTPDU 拒 绝 连 
接 ， 整 个 过 程 如 图 10-24 所 示 。 这 样 ， 通 过 三 次 握手 机 制 可 以 有 效 地 减 


少 因 延 迟 的 重复 CR TPDU 分 组 而 市 来 的 负面 影响 ， 从 而 提高 建立 连接 
的 安全 性 和 可 靠 性 。 


主机 A 主机 B 
重复 CR TPDU 


CC TPDU 
RJ TPDU 


图 10-24 重复 连接 的 三 次 握手 过 程 


10.2.4 数据 传输 


一 旦 传输 连接 建立 ， 传 输 协 议 即 进入 了 正式 的 数据 传输 阶段 。ISO 
规定 了 正常 数据 传输 和 加 速 数 据 传输 两 种 类 型 的 服务 ， 其 中 分 别 涉及 
TT_DATA.request ~ T_DATA .indication ~、 T_EXPEDITED_DATA .request 
和 T_EXPEDITED_DATA.indication 四 个 传输 服务 原 语 ， 以 及 DT 
TPDU、AK TPDU，ED TPDU、EA TPDU 四 个 TPDU。 图 10-25 表 示 了 4 
种 数据 传输 时 的 服务 原 语 和 TPDU 的 使 用 情况 ， 具 体 过 程 描 述 如 下 。 


主机 A 主机 B 
用 户 进 程 ” 传输 层 传输 层 ”用 户 进程 
[NE 一 一 > DT(seq=i)TPDU 3 > | 
T_DATA.request ' ' | 村 ' ' T_DATA.indication 
站 AK (YR_TU-NR=i+D)TPDU | 
过 | 
T_EXPEDITED.DATA_request 


2 
1 1 ED(seq=m)TPDU 


T_EXPEDITED_DATA.indication 


' EA (YR-TU-NR=m+1) TPDU 


图 10-25 数据 传输 基本 流程 


1) 当 传 输 连 接 建立 好 并 需要 发 送 普 通 数 据 时 ， 主 机 A 的 用 户 实体 
调用 T_DATA.request 传 输 服务 原 语 ( 当 发 送 加 速 数 据 时 ， 调 用 
T_EXPEDITED_DATA.request 传 输 服务 原 语 ) ， 指 示 传 输 层 协议 开始 进 


行 数据 发 送 。 普 通 数据 是 以 DT TPDU 进 行 发 送 的 (其 中 “TPDU 序 列 
号 ”字段 值 假设 为 i ; 加 速 数据 是 以 ED TPDU 进 行 发 送 的 〈 其 
中 “TPDU 序 列 号 ”字段 值 假设 为 m) 。 


说 明 如果 发 送 的 数据 是 经 过 分 段 的 ， 每 个 数据 段 的 TPDU 剖 有 子 
序列 号 (在 “可 变 部 分 ”中 ) ， 则 将 最 后 一 个 数据 段 中 的 EOT (传输 结 
束 ) 置 1; 如 果 不 是 最 后 一 个 数据 段 ， 则 该 位 置 0 。 


2) 当 数 据 到 达 主 机 B 的 传输 层 时 ， 普 通 数据 通过 
T_DATA.indication 服 务 原 语 (加 速 数 据 通 过 
T_EXPEDITED_DATA.indication 服 务 原 语 ) 向 用 户 实体 指示 有 数据 到 


达 。 


3) 如 果 收 到 的 是 普通 数据 ， 主 机 B 发 送 AK TPDU 进 行 确 认 ， 其 
中 “你 的 TPDU 序 列 号 ”(YR-TU-NR) 字段 为 希望 收 到 的 下 一 个 数据 或 
加 速 数据 TPDU 的 序列 号 ， 等 于 i+1， 但 没有 “TPDU 序 列 号 ?字段 值 。 如 
果 收 到 的 是 加 速 数 据 ， 则 主机 B 发 送 EA TPDU 进 行 确认 ， 其 中 “你 的 
TPDU 序 列 号 ”(YR-TU-NR) 字段 为 布 望 收 到 的 下 一 个 数据 或 加 速 数据 


TPDU 的 序列 号 ， 等 于 m+1。 


10.2.5 “传输 连接 释放 


传输 连接 的 释放 分 为 "对 称 释放 ”和 *“ 非 对 称 释放 "两 种 。“ 对 称 释 
放 ” 是 在 各 目 独 立 发 出 释放 连接 请 求 ， 收 到 对 方 的 释放 确认 之 后 才 可 释 
放 连 接 ;“ 非 对 称 释放 "是 在 发 送 释 放 请 求 后 单方 终止 连 氨 ， 但 这 样 做 
有 可 能 丢失 对 方 发 送 的 数据 。 


OSVRM 体 系 结构 的 传输 连接 释放 也 采用 三 次 握手 协商 方式 
(TCP/IP 体 系 结构 中 的 TCP 传 输 连接 释放 是 采用 “四 次 握手 机 制 *? 的 ， 具 
体内 容 将 在 本 章 后 面 介 绍 ) ， 其 中 也 分 “正常 释放 连接 ”和 * 非 正常 释放 
连接 ”两 种 情况 。“ 非 正常 释放 连接 ”又 包括 以 下 3 种 情况 : 最 后 的 确认 
TPDU 和 去 失 、 应 和 伦 TPDU 和 去 失 、 应 答 及 后 续 释 放 请 求 DR 丢失 。 本 世 以 对 
称 释 放 方 式 为 例 进 行 介绍 。 


正常 情况 下 的 三 次 握手 连接 释放 过 程 如 图 10-26 所 示 。 注 意 ， 图 10- 
26 中 省 略 了 释放 连接 请 求 方 用 户 实体 调用 的 T_DISCONNECTrequest 传 
输 服 务 原 语 ， 以 及 释放 连接 接受 方 用 户 实体 调用 的 
T_DISCONNECT.indication 服 务 原 语 。 其 中 使 用 的 TPDU 有 两 类 : 用 于 
请 求 释 放 连 接 的 DR TPDU、 用 于 确认 释放 连接 的 DC TPDU 。 


主机 A 主机 B 
发 送 DR 并 DR TPDU 


启动 计时 天 ee 收 到 DR， 然 后 也 发 送 


ee DR 并 启动 计时 右 
释放 连接 
Te 

释放 连接 


图 10-26 正常 情况 下 的 三 次 握手 连接 释放 过 程 


如 果 最 后 的 DC TPDU 丢 失 ， 则 三 次 所 握手 协商 过 程 如 图 10-27 所 
示 ， 最 终 的 释放 连接 请 求 会 因 超 时 而 自动 释放 。 


主机 A 主机 B 
发 送 DR 并 DR TPDU 
启动 计时 器 四 
人 收 到 DR， 然 后 也 发 送 


释放 连接 


发 送 DC ss 


因 超 时 释放 连接 


图 10-27 “最 后 的 DC TPDU 丢 失 ” 情 况 下 的 非 正 常 连接 释放 过 程 


如 果 另 一 方 的 DR TPDU 丢 失 ， 则 发 起 释放 连接 请 求 的 一 方 会 再 次 
重新 发 送 DR TPDU， 请 求 释 放 连 接 。 连 接 释 放 过 程 如 图 10-28 所 示 ， 在 
请 求 方 重 发 DR TPDU 后 释放 连接 。 


主机 A 主机 B 

发 送 DR 并 DR TPDU 

启动 [时 器 | 一 _ 
i 然后 

DR TP De 也 发 送 DR 并 
局 动 计时 需 
因 超 时 重 发 DR 并 
司 动 计 时 人 需 DRTPDU 


也 发 送 DR 并 


DR TPDU 启动 计时 器 
释放 连接 
发 送 DC DC TPDU 
释放 连接 


图 10-28 男 一 方 DR TPDU 丢 失 情 况 下 的 非 正 和 常 连接 释放 过 程 


如 果 男 一 方 的 DR TPDU 和 和 请求 方 重 发 的 DR TPDU 均 发 生 丢 失 ， 而 
且 重 发 多 次 仍 不 能 成 功 ， 则 最 后 因 传输 超时 而 导致 连接 目 动 释放 ， 过 
程 如 图 10-29 所 示 。 


主机 A 主机 B 


发 送 DR 并 DR TPDU 
启动 [器 | 一 | | 
到 DR， 然 后 
pi TPDU 也 发 送 DR 并 


启动 计时 人 需 
因 超 时 重 发 DR 并 
启动 计时 器 ss TPDU 
收 到 DR， 然 后 
也 发 送 DR 并 
启动 计时 器 
1 次 超时 gSEs 
ee 因 超 时 
释放 连接 释放 连接 


图 10-29 另 一 方 DR TPDU 和 重 发 DR TPDU 均 丢失 情况 下 的 非 正 常 连 
接 释 放 过 程 


10.2.6 ”流量 控制 


传输 层 协议 采用 的 是 在 本 章 前 面 已 多 次 提 到 的 信用 量 (CDT) 分 
配 的 窗口 机 制 ， 不 同 于 数据 链 路 层 协议 流量 控制 方案 中 的 窗口 尺寸 固 
定 的 滑动 窗口 机 制 ， 因 为 传输 层 中 的 CDT 值 是 随 着 数据 的 传输 过 程 而 
不 断 变 化 的 ‘TCP/IP 体系 结构 中 的 TCP 的 流量 控制 原理 也 是 这 样 的 ， 
本 章 后 面 将 具体 介绍 ) 。 在 传输 层 的 CR、CC、AK 三 类 TPDU 头 部 
中 ， 均 有 一 个 CDT 字 段 〈 参 见 10.1.5 节 和 10.1.6 节 ， 相 当 于 本 章 后 面 介 
绍 的 TCP 数 据 段 中 的 “窗口 大 小 ”字段 ) ， 接 收 端 利用 该 字段 向 发 送 端 
通报 当前 还 可 接收 的 TPDU 数 量 ， 即 接收 缓冲 区 大 小 ， 发 送 端 则 按 当 
前 接收 缓冲 区 容量 发 送 适 量 的 TPDU。 


在 建立 连接 时 ， 双 方 通过 CR TPDU 和 CC TPDU 中 的 CDT 字 段 撒 带 
着 相互 通告 各 自 的 初始 窗口 大 小 ， 即 初始 信用 量 。 在 数据 传输 过 程 
中 ， 发 送 端 按 接收 端 发 回 的 AK TPDU 中 的 CDT 值 发 送 一 定 的 数据 量 ; 
接收 闫 可 根据 接收 缓冲 区 的 使 用 状况 动态 地 调整 接收 窗口 大 小 ， 并 在 
发 送 AK TPDU 进 行 确 认 时 撒 带 着 将 新 的 窗口 大 小 通告 给 发 送 端 。 发 送 
并 将 按 新 的 接收 窗口 尺寸 来 调整 发 送 窗 口 大 小 ， 接 收 端 也 用 新 的 接收 
窗口 大 小 来 验证 新 到 达 数 据 分 组 的 可 接受 性 。 下 面 举 两 个 例子 来 说 明 
一 下 ， 为 了 便于 说 明 ， 假 设 双方 的 初始 窗口 大 小 相同 。 


1. 窗 口 大 小 为 1 的 数据 传输 过 程 


在 传输 连接 建立 后 ， 当 发 送 端 发 送 的 CR TPDU 和 接收 端 发 送 的 CC 
TPDU 中 的 CDT 值 均 为 1 (0001) 时 ， 表 明 发 送 端 和 接收 端的 窗口 大 小 
为 1， 即 发 送 端 发 送 一 个 TPDU 后 必须 等 待 在 接受 了 该 TPDU 的 应 答 
TPDU 后 才能 继续 传送 新 的 TPDU; 接收 端 也 类 似 ， 即 仅 当 发 送 端 发 送 
一 个 TPDU 后 ， 接 收 端 才 能 疝 发 送 端 返回 一 个 确认 TPDU。 也 就 是 说 ， 
发 送 端 发 送 一 个 ， 接 收 端 必须 确认 一 个 ， 如 图 10-30 所 示 ， 其 实 这 与 数 
据 链 路 层 的 “ 停 -等 "窗口 协议 原理 是 一 样 的 。 


主机 A 主机 B 


AK(YR-TU-NR=i1+1) TPDU 


DT1(seq=i1+1) TPDU 


AK(YR-TU-NR=i+2)TPDU 


DT(seq=i+2) TPDU 


AK(YR-TU-NR=1+3) TPDI 


10-30 ”窗口 大 小 为 1 时 的 数据 传输 过 程 


假设 发 送 端 主机 A 和 主机 B 的 初始 TPDU 序 列 号 分 别 为 下 j)， 具 体 


的 步骤 摘 述 如 下 : 


1) 主机 A 向 主机 B 发 送 第 一 个 DTTPDU， 序 列 号 为 i (seq=i) 。 
因为 窗口 大 小 为 1， 所 以 必须 等 待 对 方 收 到 并 发 回 确认 后 才能 继续 发 送 
下 一 个 DTTPDU 。 


注意 ” 仅 DT TPDU 和 ED TPDU 中 有 “TPDU 序 列 号 ”字段 ， 其 他 


TPDU 均 没有 。 


2) 主机 B 在 收 到 序列 号 为 的 DTTPDU 并 向 用 户 实体 提交 (清空 
缓存 ) 后 向 主机 A 发 送 第 一 个 确认 AK TPDU， 其 中 “你 的 TPDU 序 列 
号 ”字段 值 为 it+1， 即 YR-TU-NR=i+1 (AK TPDU 和 EA TPDU 等 均 


无 “TPDU 序 列 号 ”字段 )。 


3) 因为 主机 B 已 把 收 到 的 DT TPDU 向 用 户 实体 提交 了 ， 所 以 缓存 
为 空 ， 可 继续 向 主机 B 发 送 一 个 DTTPDU， 序 列 号 为 i+1 (seq=i+1) 。 
此 时 同样 因 窗 口 大 小 为 1， 不 能 继续 发 送 ， 需 等 待 主机 B 的 确认 
TPDU 。 


4) 主机 B 在 收 到 序列 号 为 i+1 的 DTTPDU 并 向 用 户 实体 提交 ( 清 
空 缓存 ) 后 向 主机 A 发 送 第 一 个 确认 AK TPDU， 其 中 “你 的 TPDU 序 列 
号 ”字段 值 为 t+2， 即 YR-TU-NR=i+2。 


以 后 的 步 又 就 与 前 面 介绍 的 一 样 了 ， 主 机 A 发 送 一 个 DTTPDU 后 
就 停 下 来 ， 只 有 在 收 到 主机 B 的 确认 TPDU 后 才 继 续 发 送 下 一 个 DT 
TPDU。 在 这 种 情况 下 的 特点 是 ， 只 有 发 送 端 收 到 一 个 确认 TPDU， 才 


可 以 再 发 送 一 个 新 的 DT TPDU。 当 然 ， 这 种 情况 比较 少见 ， 因 为 这 种 
窗口 机 制 不 能 有 效 地 利用 信道 货源 。 


2. 窗 口 大 小 为 3 的 数据 传输 过 程 


适当 调整 窗口 大 小 可 以 不 仅 使 接收 端 和 发 送 端 速率 相 匹配 ， 还 可 
以 充分 利用 现 有 带宽 资源 ， 提 高 传输 效率 。 如 果 在 CR TPDU 和 CC 
TPDU 中 设置 CDT 为 3， 即 双方 的 窗口 大 小 均 为 3， 则 发 送 端 可 以 在 第 
一 次 连续 发 送 3 个 DTTPDU 后 再 停 下 来 等 得 接收 并 的 一 个 或 多 个 确认 
信息 ， 接 收 端 也 类 似 。 但 是 发 送 端 和 接收 端 并 不 是 每 次 都 可 以 连接 发 
送 3 个 TPDU， 要 视 对 方 返 回 的 确认 TPDU 确 认 数 多 少 而 定 ， 其 实 也 就 
是 要 视 对 方 当 前 可 用 缓存 空间 大 小 而 定 。 


10-31 有 是 在 窗口 大 小 为 3 的 情况 下 的 数据 传输 过 程 ， 具 体 摘 述 如 
下 


主机 A 主机 B 


DT(seq=i+1) TPDU 


DT(seq=1+2) TPDU 


AK(YR-TU-NR=i1+1) TPDU 


DT(seq=i+3) TPDU 
AK(YR-TU-NR=i+2) TPDU 
AK(YR-TU-NR=i+3) TPDU 


DT(seq=i1+4) TPDU 


DT(seq=i+5) TPDU 


10-31 窗口 大 小 为 3 时 的 数据 传输 过 程 


1) 主机 A 向 主机 B 连 续 发 送 3 个 DTTPDU， 序 列 号 分 别 为 i 
(seq=i) 、 计 1 (seq=i+1) 和 i+2 (seq=i+2) 。 因 为 窗口 大 小 为 3， 所 
以 必须 等 待 对 方 收 到 并 发 回 确认 (相当 于 清空 部 分 或 全 部 缓存 ;后 才 
能 继续 发 送 下 一 个 DT TPDU。 


2) 主机 B 在 收 到 前 面 3 个 DTTPDU 后 ， 依 次 向 用 户 实体 提交 ， 并 
依次 向 主机 A 发 送 确认 AK TPDU。 现 假设 主机 A 收 到 了 主机 B 的 第 一 个 
AK TPDU,“ 你 的 TPDU 序 列 号 ”字段 值 为 t+1。 此 时 ， 在 AK TPDU 中 
CDT 为 1， 表 示 可 以 再 接收 一 个 TPDU 。 


3) 在 收 到 主机 B 发 来 的 第 一 个 AK TPDU 后 ， 看 到 其 中 的 CDT 值 为 
1， 于 是 马上 回 主 机 B 发 送 下 一 个 DT TPDU， 序 列 号 为 i+3 
(seq=i+3) 。 此 时 ， 还 没有 收 到 新 的 来 自主 机 B 的 AK TPDU， 表 明 对 
方 没有 可 用 缓存 空间 了 ， 需 要 停 下 来 ， 继 续 等 待 来 自主 机 B 新 的 确认 
TPDU。 


4) 现 假设 主机 A 在 很 短 的 间隔 时 间 内 几乎 同时 收 到 了 两 个 AK 
TPDU,“ 你 的 TPDU 序 列 号 ”字段 值 分 别 为 t+2 和 i+3。 主 机 A 从 后 面 收 到 
的 AK TPDU 中 的 CDT 值 得 知 主机 B 目 前 可 以 再 接收 两 个 TPDU， 于 是 
又 连续 向 主机 B 发 送 两 个 DTTPDU， 序 列 号 分 别 为 i+4 (seq=i+4) 、 
i+5 (seq=i+5) 。 


随后 的 步骤 与 前 面 介绍 的 类 似 。 总 之 ， 需 要 注意 的 一 个 原则 是 ， 
发 送 端的 主机 A 收 到 了 来 目 接收 端的 主机 B 的 多 少 个 确认 TPDU， 束 可 
继续 发 送 多 个 DTP TPDU， 发 送 窗口 大 小 不 是 固定 的 。 


在 传输 层 中 ， 还 具有 数据 绥 冲 的 功能 ， 虽 然 这 也 与 数据 链 路 层 的 
数据 缓冲 功能 类 似 ， 但 所 采取 的 措施 不 一 样 。 传 输 层 的 缓存 策略 和 管 
理 方法 包括 缓存 方式 和 策略 、 发 送 端 申请 /接收 端 分 配 、 接 收 端 在 应 答 
中 来 市 新 的 分 配 信 息 、 阻 塞 和 洪 在 死 锁 等 几 个 方面 ， 在 此 不 进行 介绍 
了 。 


10.2.7 多 路 复 用 


在 传输 层 也 可 以 采取 多 路 复 用 (session multiplexing) 技术 来 提高 
传输 连接 的 利用 率 。 传 输 层 的 多 路 复 用 可 以 是 由 多 个 传输 连接 复 用 同 
一 个 网 络 连接 的 网 上 多 路 复 用 方式 ， 也 可 以 是 由 一 个 传输 连接 在 多 个 
网 络 连 接 上 循环 传输 的 网 下 多 路 复 用 方式 。 


假设 一 台 机 器 只 有 一 个 网 络 地址 可 以 使 用 ， 那 么 这 人 台 机 器 上 的 所 
有 传输 连接 都 必须 使 用 这 一 个 网 络 地 址 ， 这 就 是 向 上 多 路 复 用 方式 ， 
如 图 10-32 所 示 。 当 一 个 TPDU 进 来 的 时 候 ， 传 输 实体 需要 用 一 种 方法 
来 指明 应 该 将 它 交 给 哪个 应 用 进程 ， 这 个 方法 就 是 利用 不 同 传输 连接 
所 而 使 用 不 同 的 端口 号 。 


TSAP 


图 10-32 向 上 多 路 复 用 示意 图 


还 有 一 种 情况 ， 在 一 个 子 网 中 使 用 了 虚 电 路 ， 并 且 每 条 虚 电 路 上 
有 最 大 的 数据 传输 速率 限制 ， 当 某 个 传输 连接 所 需 的 带宽 超过 某 一 条 
虚 电 路 所 能 提供 的 带宽 时 ， 就 需要 将 这 个 传输 连接 以 轮 循 的 方式 把 数 
据 流 分 配 在 不 同 的 网 络 连接 上 ， 这 就 是 向 下 多 路 复 用 方式 ， 如 图 10-33 
所 示 。 向 下 多 路 复 用 方式 的 典型 应 用 是 ISDN 用 户 线路 ， 因 为 普通 的 家 
庭 ISDN 中 每 条 线路 只 有 64kbits， 通 过 复 用 两 条 线路 ， 最 终 达到 
128kbits 的 带宽 。 


E 


从 民 一 人 


10-33” 问 下 多 路 复 用 示意 图 


10.2.8 ”前 尝 恢 复 


在 传输 连接 中 由 于 过 到 主机 或 路 由 器 不 能 正常 工作 而 造成 TPDU 
传输 过 程 中 断 的 现象 称 为 月 江 。 月 演 恢 复 就 是 要 恢复 到 崩 江 前 的 工作 
状态 ， 继 续 TPDU 传 输 。 要 实现 这 样 一 项 功能 ， 必 须 解决 在 月 普 前 发 
送 的 最 后 一 个 TPDU 是 否 需 要 重 传 的 问题 。 


如 膝 网 络 层 提供 数据 报 服 务 ， 束 需要 传输 实体 留 有 丢失 的 TPDU 
的 副本 ;， 如 采 网 络 层 提供 面 同 连接 的 服务 ， 则 重建 新 的 虚 电 路 ， 重 发 
丢失 的 TPDU。 要 从 主机 或 服务 右 朋 演 中 恢复 ， 存 在 着 许多 复业 的 问 
题 ， 在 此 不 进行 讨论 。 


总 体 来 说 ， 从 第 N 层 前 总 中 恢复 只 能 由 第 N+1 层 来 完成 ， 并 且 只 能 
在 第 N+1 层 留 有 足够 状态 信息 的 情况 下 才能 完成 。 


对 于 传输 层 朋 溃 恢 复 ， 需 要 和 完了 解 在 朋 浇 前 发 送 主 机 和 接收 主机 
的 状态 ， 以 及 发 送 主机 对 最 后 TPDU 的 处 理 。 崩 演 恢 复工 作 必 须 由 更 
高 层次 (应 用 层 ) 来 完成 ， 具 体 的 连接 恢复 机 制 参见 10.4 世 中 介绍 的 
TCP 连 接 可 靠 性 内 容 。 


10.3 ”TCP 概 壕 


前 面 主 要 介绍 了 OSIRM 体 系 结构 中 的 传输 层 服务 ， 本 节 要 具体 介 
绍 TCP/IP 体 系 结构 中 的 主要 传输 层 协 议 一 一 TCP (传输 控制 协议 ) ， 
其 中 包括 TCP 的 一 些 主要 特性 和 在 本 章 前 面 介绍 的 各 种 传输 服务 功能 
实现 的 原理 。 


10.3.1 TCP 的 主要 特性 


TCP 古 TCP/IP 体 系 结构 中 最 主要 的 传输 层 协 议 ， 在 功能 上 与 本 章 
前 面 介 绍 的 OSI 网 络 中 的 TP4 类 传输 层 协 议 类 似 ， 但 TCP 只 能 提供 面向 
连接 的 传输 服务 ， 而 且 TCP 还 具有 以 下 主要 特性 : 
(1) 面向 连接 的 传输 协议 
也 就 是 说 ， 应 用 程序 在 使 用 TCP 之 前 ， 必 须 先 建 立 TCP 传 输 连 
接 ， 在 传输 数据 完毕 后 ， 必 须 释 放 已 建立 的 TCP 传 输 连 接 。 
(2) 仅 文 持 单 播 传输 


每 条 TCP 传 输 连 接 只 能 有 两 个 端点 ， 只 能 进行 点 对 点 的 数据 传 
输 ， 不 支持 多 播 (multicast) 和 广播 (broadcast) 传输 方式 。 


说 明 这 里 所 说 的 TCP 传 输 连 接 的 “ 哨 点 "不 是 主机 、 主 机 的 了 地 
址 、 应 用 进程 、 传 输 层 协议 端口 ， 而 是 套 接 字 (socket) 。 套 接 字 是 PP 
地 址 和 病 口 号 的 组 合 ， 中 间 用 冒号 或 逗号 分 隅 ， 如 


(192,168.10,80) 。 每 个 TCP 传 输 连 接 有 两 个 端点 ， 也 就 是 有 两 个 套 
接 字 ， 即 “ 源 IP 地 址 和 端口 号 ”组 合 和 “目的 IP 地 址 和 端口 号 组合， 可 


表示 为 { socketl,socket2 } ， 或 者 { (IP1,Portl ) , (IP2,Port2 ) } 。 


(3) 提供 可 靠 的 交付 服务 


也 就 是 说 ， 通 过 TCP 连 接 传送 的 数据 可 以 无 差错 、 不 丢失 、 不 重 
复 ， 且 按时 序 到 达 对 端 。 


(4) 传输 单位 为 数据 段 


TCP 仍 采用 了 传统 的 “数据 段 " 作 为 数据 传输 单元 。 由 于 数据 段 大 
小 受 应 用 层 传送 的 报 文大 小 和 所 途经 网 络 中 MTU 值 大 小 决定 ， 所 以 每 
次 发 送 的 TCP 数 据 段 大 小 是 不 固定 的 。 在 一 个 具体 的 网 络 中 ， 有 一 个 
MSS (Maximum Segment Size， 最 大 数据 段 大 小 ) ， 最 小 的 数据 段 可 
能 仅 有 21 字 节 (其 中 20 字 节 属 TCP 数 据 段 头 部 ， 数 据 部 分 仅 1 字 节 ) 。 


(5) 仅 一 种 TPDU 格 式 


TCP 的 数据 传输 数据 单元 称 为 “数据 段 *>， 其 实 也 可 以 按照 OSURM 
中 的 说 法 称 为 TPDU。 在 TCP 中 只 有 一 种 TPDU， 而 不 会 像 OSIURM 中 有 


很 多 种 不 同 格式 的 TPDU (具体 参见 10.1.5 节 ~10.1.7 节 ) ， 因 为 在 TCP 
数据 段 头 部 已 包括 了 各 种 TPDU 所 需 的 特征 字段 ， 主 要 是 通过 其 中 的 
多 个 控制 位 来 实现 的 ， 具 体 将 在 说 明 TCP 数 据 段 格式 时 介绍 。 


(6) 支持 全 双 工 传输 


TCP 人 允许 通信 双方 的 应 用 程序 在 任何 时 候 部 能 发 送 数 据 ， 因 为 
TCP 连 接 的 两 端 都 设 有 发 送 和 缓存 ， 用 来 临时 存放 双 回 通信 的 数据 。 
当然 ，TCP 可 以 立即 发 送 一 个 数据 段 ， 也 可 以 缓存 一 段 时 间 以 便 一 次 
发 送 更 多 的 数据 段 (最 大 的 数据 段 大 小 取决 于 MSS) 。 


(7) TCP 连 接 是 基于 字 市 流 的 ， 而 非 报 文 流 


TCP 不 像 UDP 那 样 以 一 个 个 报 文 独立 地 进行 传输 ， 而 是 在 不 保留 
报 文 边界 的 情况 下 以 字 节 流 方式 进行 传输 。 


(8) 每 次 发 送 的 TCP 数 据 段 大 小 和 数据 段 数 都 是 可 变 的 


在 TCP 中 ， 因 为 每 次 发 送 多 少 字 节 的 数据 不 是 固定 的 ， 也 不 是 由 
主机 当前 可 用 缓存 决定 的 ， 而 是 根据 对 方 给 出 的 窗口 大 小 和 当前 网 络 
的 拥塞 程度 来 决定 的 〈 本 章 后 面 将 要 介绍 的 UDP 发 送 的 报 文 长 度 是 由 
应 用 进程 给 出 的 ) ， 所 以 每 次 可 以 发 送 的 TCP 数 据 大 小 是 不 固定 的 。 


TCP 的 传输 单元 是 数据 段 ， 数 据 段 又 是 在 应 用 层 传送 的 数据 基础 
上 进行 封 次 的 ， 每 次 的 TCP 数 据 段 大 小 取决 于 不 同 的 应 用 进程 数据 。 


当然 ， 如 果 应 用 层 传送 的 报 文 太 长 ， 超 出 了 MSS， 则 需要 对 报 文 进行 
分 段 ， 忌 的 来 说 ， 每 次 传输 的 TCP 数 据 段 大 小 是 由 应 用 层 数据 和 MSS 
双重 决定 的 。 


这 样 一 来 ， 每 次 可 以 发 送 的 TCP 数 据 段 数 也 是 不 固定 的 ， 可 以 一 
次 仅 发 送 一 个 ITCP 数 据 段 ， 也 可 以 一 次 发 送 多 个 TCP 数 据 段 ， 只 要 在 
当前 可 用 的 “发 送 窗口 大 小 ”限制 之 内 即 可 。 田 外 ， 如 末 应 用 进程 传送 
到 TCP 绥 存 中 的 数据 太 长 ，TCP 可 以 对 它 进行 分 段 ， 反之， 如 果 传 到 
TCP 绥 存 中 的 数据 太 小 ， 则 TCP 会 等 生 级 存 中 有 足够 多 的 数据 后 再 组 
装 成 一 个 数据 段 一 起 发 送 。 


10.3.2” TCP 数据 段 格 式 


前 面 讲 过 ，TCP 的 协议 数据 单元 仍 采 用 传统 意义 上 的 叫 法 ， 称 为 
Segment (分 段 ) ， 而 没有 像 OSVLRM 中 的 那样 称 为 TPDU， 当 然 两 者 本 
质 上 其 实 是 一 致 的 。 所 使 用 的 TCP 软 件 决 定 了 数据 段 的 大 小 ， 可 以 将 多 
次 写 操作 中 的 数据 累积 起 来 放 到 一 个 数据 段 中 ， 也 可 以 将 一 次 写 操作 
的 数据 分 割 成 多 个 数据 段 。 有 两 个 因素 决定 了 数据 段 的 大 小 : 一 是 每 
个 TCP 数 据 段 的 大 小 必须 符合 IP 数 据 包 的 65515 字 下 的 有 效 载 傈 大 小 限 
制 要 求 ， 二 是 每 个 网 络 都 有 一 个 MTU 值 ， 因 此 ， 每 个 TCP 数 据 段 必须 
符合 MTU 的 限制 要 求 。 


TCP 通 过 数据 段 的 交互 来 建立 连 授 、 传 输 数 据 、 发 出 确认 、 进 行 差 
阁 控 制 、 流 量 控 制 及 关闭 连接 。 整 个 TCP 数 据 段 也 分 为 “数据 段 
头 ” 和 “数据 ”两 部 分 (这 也 是 绝 大 多 数 报 文 封装 的 方式 ) ， 所 谓 “ 数 据 段 
头 ” 束 是 TCP 为 了 实现 端 到 病 可 徘 传输 而 加 上 的 TCP 挥 制 信息 ， 而 仇 
据 ” 部 分 则 是 指 由 高 层 ( 即 TCP/IP 体 系 结构 中 的 “应 用 层 ”) 来 的 用 户 数 
据 。 但 由 于 TCP 中 只 有 一 种 TPDU 格 式 ， 所 有 类 型 的 数据 段 格式 都 统一 
在 如 图 10-34 所 示 的 TCP 数 据 段 格式 中 ， 不 同类 型 数据 段 是 通过 其 中 的 
多 个 控制 位 来 实现 的 。 下 面 是 其 中 各 字段 的 具体 说 明 。 


0 15 31 位 


源 端口 目的 端口 
序号 
确认 号 数据 段 头 
TCP“ 数 据 段 头 ” 
数据 仿 保留 |RICISISIYI 窗口 大 小 部 分 
GIKIHITININ 
校 验 和 紧急 指针 


可 选项 ( 0 或 多 个 32 位 ) 


数据 


图 。10-34 ”TCP 数据 段 格式 
(1) 源 端 口 和 目的 端口 


源 问 口 和 目的 端口 分 别 代表 呼叫 方 和 被 叫 方 的 TCP 端 口号 ， 各 占 16 
位 。 一 个 问 口 与 其 主机 的 JP 地址 束 可 以 完整 地 标识 一 个 端点 了 ， 也 残 
是 构成 了 前 面 所 说 的 套 接 字 (Socket) 。 


(2) 序号 (Sequence Number) 


序号 指 TCP 数 据 段 中 的 “数据 ?部 分 (不 包含 “数据 段 头 ” 部 分 的 第 
一 个 字 节 的 编号 ， 占 32 位 。 在 一 个 TCP 连 接 中 ， 传 送 的 数据 字 节 流 中 的 
每 一 个 数据 字 下 都 要 按 顺 序 进行 编号 ， 在 “数据 段 头 "中 标识 的 只 是 每 
个 数据 段 的 第 一 个 数据 字 节 的 编号 。 整 个 要 传送 的 字 市 流 的 起 始 序 号 
必须 在 连接 建立 时 设置 。 例 如 ， 一 个 数据 段 的 “序号 ”字段 值 是 101， 而 


该 数字 段 中 共有 100 字 节 ， 表 明 本 数据 段 的 最 后 一 个 字 万 的 编号 是 
200。 这 样 一 来 ， 下 一 个 数据 段 的 “序号 ”字段 值 应 该 是 201， 而 不 是 
102， 这 点 要 特别 注意 。 


(3) 确认 号 (Acknowlegment Number) 


确认 号 指 期 望 接收 到 对 方 下 一 个 数据 段 中 “数据 ”部 分 的 第 一 个 字 
廊 序 号 ， 占 32 位 。 注 意 ,， “确认 号 "不 是 代表 已 经 正确 接收 到 的 最 后 一 
个 字 市 的 序号 。 例 如 ， 主 机 B 已 收 到 主机 A 发 来 的 一 个 数据 段 ， 其 序号 
值 是 101， 而 该 数据 段 的 长 度 是 100 字 节 。 这 表明 主机 B 已 收 到 主机 A 前 
200 个 字 廊 ， 下 一 个 期 望 要 收 到 的 数据 段 的 第 一 个 字 市 的 序号 应 该 是 
201， 于 是 主机 B 在 给 主机 A 发 送 确认 数据 段 时 要 把 “确认 写 ” 设 置 为 
201。 


“序号 "和 < 确认 号 "两 个 字段 共同 用 于 TCP 服 务 中 的 差错 控制 ， 确 保 
TCP 数 据 传输 的 可 靠 性 ， 具 体内 容 将 在 本 章 后 面 介绍 。 


(4) 数据 偏 移 


数据 偏 移 指数 据 段 中 的 “数据 ”部 分 起 始 处 距离 TCP 数 据 段 起 始 处 的 
字 太 仿 移 量 ， 占 4 位 。 其 实 这 里 的 “数据 偏 移 ” 也 是 在 确定 TCP 数 据 段 尖 
部 分 的 长 度 ， 因 为 “数据 ”部 分 是 紧 接 着 数据 段 尖 的 。 因 为 TCP 数 据 段 头 
中 有 不 确定 的 “可 选项 ”字段 ， 所 以 数据 偏 移 字段 是 非常 必要 。 但 要 注 
意 的 是 ， 数 据 偏 移 量 是 以 32 位 〈 即 4 字 节 ) 为 单位 来 计算 的 ， 而 不 是 以 


单个 字 市 来 计算 的 。 因 为 4 个 比特 位 可 以 表示 的 最 大 数 为 15， 所 以 数据 
偏 移 量 最 大 为 60 字 节 ， 这 也 是 TCP 数 据 段 头 部 分 的 最 大 长 度 。 


(5) 保留 (Reserved) 


这 是 为 将 来 应 用 而 保留 的 6 个 比特 位 ， 目 前 应 全 设置 为 0。 


(6) URG 


Urgent Pointer (紧急 指针 ) 控制 位 ， 指 出 当前 数据 段 中 是 否 有 紧 
急 数据 ， 占 1 位 ， 置 1 时 表示 有 紧急 数据 。 紧 急 数据 会 优先 安排 传送 ， 
而 不 会 按照 原来 的 排队 顺序 进行 发 送 ， 相 当 于 本 章 前 面 介 绍 OSWRM 传 
输 层 TPDU 时 所 说 的 “加 速 数据 ”。 仅 当 本 字段 的 置 1， 后 面 的 “紧急 指 
计 " 尝 段 直 有 意义 


(7) ACK 


Acknowledgement (确认 ) 控制 位 ， 指 示 TCP 数 据 段 中 的 “确认 
号 ?字段 是 否 有 效 ， 占 1 位 。 仅 当 ACK 位 置 1 时 才 表 示 “ 确 认 号 ?字段 有 
效 ， 否 则 表示 “确认 号 ”字段 无 效 ， 应 用 层 实 体 在 读 取 数 据 时 可 以 不 


“确认 号 ?字段 。 


vt 


芭 


(8) PSH 


Push 〈 推 ) 控制 位 ， 指 示 有 是 否 需要 立即 把 收 到 的 该 数据 段 提交 给 
应 用 进程 ， 占 1 位 。 当 PSH 位 置 1 时 要 求 接收 器 尽快 把 该 数据 段 提 区 给 应 
用 进程 ， 而 置 0 时 没 这 个 要 求 ， 可 以 和 匈 缓 存 起 来 。 


(9) RST 


Reset ( 重 置 ) 控制 位 ， 用 于 重 置 、 释 放 一 个 已 经 混乱 的 传输 连 
接 ， 然 后 重建 新 的 传输 连接 ， 占 1 位 。 当 RST 位 置 1 时 ， 释 放 当 前 传输 连 
接 ， 然 后 可 以 重新 建立 新 的 传输 连接 。 


(10) SYN 


Synchronization (同步 ) 控制 位 ， 用 来 在 传输 连接 建立 时 同步 传输 
连接 序号 ， 占 1 位 。 当 SYN 位 置 1 时 ， 表 示 这 是 一 个 连接 请 求 或 连接 确 
认 报 文 。 当 SYN=1， 而 ACK=0 时 ， 表 明 这 是 一 个 连接 请 求 数据 段 〈 相 
当 于 本 章 前 面 介 绍 的 OSURM TPDU 中 的 CR TPDU) 。 如 果 对 方 同 意 建 
立 连接 ， 则 对 方 会 返回 一 个 SYN=1、ACK=1 的 确认 (相当 于 本 章 前 面 
介绍 的 OSURM TPDU 中 的 CC TPDU) 。 


(11) FIN 


Final (最 后 ) 控制 位 ， 用 于 释放 一 个 传输 连接 ， 占 1 位 。 当 FIN 位 
置 1 时 ， 表 示 数 据 已 全 部 传输 完成 ， 发 送 端 没有 数据 要 传输 了 ， 要 求 释 


放 当 前 连接 ， 但 是 接收 端 仍然 可 以 继续 接收 还 没有 接收 完 的 数据 。 在 
正常 传输 时 ， 该 位 置 0。 


(12) 窗口 大 小 


指示 发 送 此 TCP 数 据 段 的 主机 上 用 来 存储 传 入 数据 段 的 窗口 大 小 ， 
也 即 发 送 者 当前 还 可 以 接收 的 最 大 字 节 数 ， 相 当 于 本 章 前 面 介绍 
OSIRM TPDU 中 的 CDT (信用 量 分 配 ) ， 占 16 位 。TCP 的 “窗口 大 
小 ”字段 与 本 章 前 面 介 绍 的 CDT 一 样 是 使 用 可 变 大 小 的 滑动 窗口 协议 来 
进行 流量 控制 。“ 和 窗口 大 小 ”字段 的 值 告诉 接收 本 数据 段 的 主机 ， 从 本 
数据 段 中 所 设置 的 “确认 号 ” 值 算 起 ， 本 端 目 前 允许 对 端 发 送 的 字 节 
数 ， 是 作为 让 对 方 设 置 其 发 送 窗口 大 小 的 依据 。 假 设 本 次 所 发 送 的 数 
据 段 的 “确认 号 ?字段 值 501， 而 “窗口 大 小 ”字段 值 是 100， 则 从 501 算 
起 ， 本 端 还 可 以 接收 100 字 节 ( 字 节 序号 是 501~600) 。 


(13) 检验 和 (Checksum) 


检验 和 是 指 对 “数据 段 头 ”\“ 数 据 ? 和 "“ 伪 头 部 ”这 三 部 分 进行 校 验 ， 
占 16 位 。“ 伪 头 部 ”包括 源 主机 和 目的 主机 的 32 位 IP 地 址 、TCP 协 议 号 
(6) ， 以 及 TCP 数 据 段 长 度 。 若 要 了 解 校 验 和 原理 ， 可 参见 7.3.4 节 相 
关内 容 。 


(14) 紧急 指针 (Urgent Pointer) 


仅 当 前 面 的 URG 控 制 位置 1 时 才 有 意义 ， 它 指出 本 数据 段 中 为 紧急 
数据 的 字 广 数 ， 占 16 位 。“ 紧 急 指 针 ” 了 字段 指明 了 紧急 数据 的 末尾 在 数 
据 段 中 的 位 置 。 当 所 有 紧急 数据 处 理 完 后 ，TCP 就 会 告诉 应 用 程序 恢复 
到 正 闻 操作。 要 注意 的 一 点 是 ， 即 使 当前 窗口 大 小 为 0， 也 是 可 以 发 送 
紧急 数据 的 ， 因 为 紧急 数据 无 须 缓存 。 


(15) 可 选项 (Option) 


“可 选项 ”字段 是 可 选 的 ， 且 长 度 可 变 ， 最 长 可 达 40 字 节 。 当 没有 
使 用 该 字段 时 ，TCP 头 部 的 长 度 是 20 字 有。 它 可 以 包括 窗口 缩放 选项 
(Window Scale Option，WSopt) 、MSS (最 大 数据 段 大 小 ) 选项 、 

SACK (选择 性 确认 ) 选项 、 时 间 戳 〈Timestamp) 选项 等 。 


(16) 数据 (Data) 


这 是 由 应 用 层 的 应 用 进程 提交 的 数据 ， 作 为 TCP 数 据 段 的 “ 数 
据 ”(\ 有 效 载荷 ) 部 分 。 


10.3.3” TCP 套 接 字 


在 本 章 前 面 介 绍 OSURM 的 传输 层 服务 时 ， 提 到 过 传输 通信 两 端的 
端点 就 是 TSAP 地 址 ， 对 应 的 就 是 传输 层 协 议 端 口 。 在 TCP/IP 网 络 中 ， 
同样 有 端点 的 概念 ， 但 它 并 不 是 直接 采用 OSVRM 中 的 TSAP 叫 法 ， 而 
是 称 为 “ 套 接 字 ”(Socket) ， 就 像 在 TCP 中 仍然 把 所 传输 的 数据 称 
为 “数据 段 *， 而 没有 采用 OSIRM 中 的 TPDU 叫 法 一 样 。 当 然 ， 需 要 说 
明 的 是 ，Socket 并 不 能 直接 等 同 于 TSAP， 它 们 只 是 类 似 ， 实 际 上 
Socket 只 是 利用 了 TSAP 地 址 ， 因 为 在 它 所 包括 的 一 组 参数 中 就 有 TSAP 
地 址 一 端口 。“ 套 接 字 ”最 早 使 用 于 UNIX 操 作 系统 中 ， 后 来 被 广泛 地 
应 用 于 Windows 和 Linux 系 统 中 ， 成 为 了 事实 上 的 TCP 标 准 。 


1. 套 接 字 概述 


在 TCP/IP 网 络 中 ， 区 分 不 同 应 用 程序 进程 间 的 网 络 通 信和 连接 时 
主要 有 以 下 3 个 参数 : 通信 的 目的 了 地址 、 使 用 的 传输 层 协议 (TCP 或 
UDP) 和 使 用 的 端口 号 (此 处 说 明 一 下 ，Socket 不 仅 在 TCP 中 有 ， 在 
UDP 中 也 同样 有 ) 。 通 过 将 这 3 个 参数 结合 起 来 ， 与 一 个 Socket 进 行 绑 
定 ， 应 用 层 就 可 以 与 传输 层 一 起 通过 套 接 字 接 口 区 分 来 自 不 同 应 用 程 
序 进程 或 网 络 连接 的 通信 ， 实 现 数据 传输 的 并 发 服务 。 为 了 区 别 不 同 
的 应 用 程序 进程 和 连接 ， 许 多 计算 机 操作 系统 为 应 用 程序 与 TCP/IP 交 
互 提供 了 称 为 套 接 字 (Socket) 的 接口 。 


Socket 可 以 看 成 是 在 两 个 网 络 应 用 程序 进行 通信 连接 时 的 一 个 端点 
(或 者 称 为 “逻辑 接口 ， 它 是 连接 应 用 程序 和 网 络 驱动 程序 的 桥 
架 ， 如 图 10-35 所 示 。 从 位 置 上 看 ， 它 与 本 草 前 面 介 绍 的 TSAP 是 不 一 样 
的 ， 因 为 TSAP 是 位 于 传输 层 上 边缘 (但 仍 属 于 传输 层 ) ， 而 Socket 是 
完全 位 于 应 用 层 ， 但 它 调用 了 传输 层 的 端口 。Socket 包 括 了 TSAP 地 


址 ， 同 样 它 还 包括 了 在 本 章 前 面 所 介绍 的 服务 原 语 ， 具 体内 容 将 在 本 
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节 后 面 介绍 。 


网 际 互 连 层 “i 


网 络 访问 层 


图 10-35 Socket 接口 的 位 置 


在 TCP/IP 通 信 中 ， 应 用 程序 把 数据 传送 给 Socket， 然 后 由 Socket 通 
过 传输 层 向 下 提交 给 网 络 驱 动 程序 并 疝 网 络 上 发 送出 去 。 计 算 机 从 网 
络 上 收 到 与 该 Socket 绑 定 IP 地 址 和 端口 号 相关 的 数据 后 ， 由 网 络 驱 动 程 


序 通过 传输 层 向 上 提交 给 应 用 层 的 Socket， 最 后 应 用 程序 从 Socket 中 提 
取 所 要 接收 的 数据 。 通 信 双 方 计算 机 上 的 网 络 应 用 程序 就 是 这 样 通 过 
Socket 进 行 数据 的 发 送 与 接收 的 ， 基 本 交互 过 程 如 图 10-36 所 示 。 


图 10-36 ”Socket 在 TCP/IP 通 信 中 的 交互 应 用 


从 图 10-36 中 可 以 看 出 ， 在 应 用 层 上 ， 针 对 每 个 应 用 进程 都 有 一 个 
Socket， 用 来 调用 传输 层 中 的 一 个 特定 端口 (当然 ， 这 个 端口 对 于 常规 
服务 来 说 是 固定 的 ， 而 对 于 非常 规 服务 来 说 不 是 固定 的 ) 。 也 就 是 
说 ， 应 用 层 的 Socket 和 传输 层 的 端口 都 有 很 多 ， 但 位 于 网 络 层 ， 对 于 一 
台 具 体 的 主机 和 具体 的 网 络 来 说 ， 它 的 人 P 地 址 却 是 唯一 的 ， 也 只 有 
Socket 和 端口 与 JP 地 址 之 间 是 “多 对 一 ”的 关系 。 


2.Socket 原 语 


在 TCP Socket 中 ， 包 括 了 如 表 10-6 所 示 的 一 组 ( 共 8 个 ) TCP 数 据 
传输 服务 原 语 。 表 中 前 4 个 原 语 由 服务 器 按照 顺序 执行 (但 并 不 是 说 服 
务 器 仅 调用 这 4 个 原 语 ) 。 其 中 ，SOCKET 原 语 用 来 创建 一 个 新 的 端 
点 ， 并 且 在 传输 实体 中 为 它们 分 配 相 应 的 空间 。SOCKET 原 语调 用 成 
功 后 ， 返 回 一 个 普通 的 文件 描述 符 ， 以 便 在 后 续 其 他 的 原 语调 用 中 使 
用 。 但 由 于 新 创建 的 套 接 字 并 没有 网 络 地 址 ， 需 要 通过 BIND 原 语 为 它 
进行 分 配 ， 所 以 BIND 原 语 的 用 途 就 是 为 新 建 的 套 接 字 绑 定 一 个 本 地 网 
络 地 址 。 


表 10-6 TCP Socket 原 语 


原 语 名 称 含 义 

SOCKET 创建 一 个 新 的 通信 端点 

BIND 将 一 个 本 地 地 址 关联 到 一 个 套 接 字 上 
LISTEN 通告 愿意 接受 连接 ， 并 给 出 队列 大 小 
ACCEPT 阻塞 调用 方 ， 直 到 有 人 企图 进行 连接 
CONNET 主动 尝试 建立 一 个 连接 

SEND 在 指定 的 连接 上 发 送 数据 

RECV 从 指定 的 连接 上 接收 数据 

CLOSE 释放 指定 的 连接 


BIND 原 语 执行 后 需要 调用 LISTEN 原 语 ， 它 为 新 建 的 套 接 字 分 配 
一 定 的 缓存 空间 ， 以 便 让 后 面 要 进来 的 连接 进行 排队 ， 这 样 就 可 以 使 
多 个 客户 可 以 同时 对 一 个 服务 器 进行 访问 。 但 此 时 服务 器 还 不 是 阻 
塞 状 态 ， 也 就 是 服务 器 仍 没 有 进入 等 待 连接 状态 ， 这 里 再 需要 调用 一 
个 ACCEPT 原 语 。 当 一 个 请 求 连接 的 TCP 数 据 段 到 来 时 ， 传 输 实体 会 通 
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过 调用 ACCEPT 原 语 创建 一 个 新 的 套 接 字 ， 并 返回 一 个 与 其 关联 的 文件 
描述 行 。 这 个 新 的 套 接 字 与 原来 由 SOCKET 原 语 创 建 的 套 接 字 具 有 相 
同 的 属性 。 这 时 ， 服 务 右 就 可 以 调用 一 个 进程 来 处 理 这 个 套 接 字 上 新 
的 连接 ， 而 服务 器 本 身 又 回去 继续 等 待 原 套 接 字 上 的 下 一 个 连接 。 


以 上 介绍 的 是 由 服务 器 调用 的 4 个 原 语 ， 而 在 客户 端 使 用 的 原 语 主 
要 包括 SOCKET、CONNECT、SEND、RECV。 首 先 ， 由 SOCKET 原 语 
创建 一 个 新 的 套 接 字 ， 但 由 于 服务 器 并 不 关心 它 所 用 的 网 络 地 址 ， 所 
以 客户 端 不 必 调 用 BIND 原 语 。 然 后 ， 通 过 CONNECT 原 语 阻塞 客户 
端 ， 并 主动 发 起 一 个 TCP 传 输 和 连接 。 当 CONNECT 原 语调 用 完成 ， 即 收 
到 服务 器 端 发 来 的 确认 数据 段 后 ， 客 户 端 解除 阻塞 状态 ， 建 立 传输 连 
接 。 到 此 为 止 ， 双 方 都 可 以 使 用 SEND 和 RECV 原 语 在 建立 起 来 的 全 双 
工 连接 上 进行 数据 的 接收 或 发 送 。 


服务 器 和 客户 端 都 可 以 调用 CLOSE 原 语 ， 用 来 释放 当前 TCP 传 输 
连接 。 当 双方 都 执行 了 CLOSE 原 语 后 ， 连 接 才 会 真正 释放 。 


TCP Socket 原 语调 用 的 基本 流程 如 图 10-37 所 示 。 


服务 天 


SOCKET 
BIND 
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图 10-37 TCP Socket 原 语调 用 的 基本 流程 


10.3.4 ” TCP 闹 口 


在 上 文 已 经 提 到 过 ， 传 输 层 TSAP 地 址 就 是 传输 层 协议 端口 ， 是 对 
网 络 应 用 进程 的 一 种 标识 。 这 里 要 区 分 “端口 "与 “接口 ?两 个 不 同 概念 ， 
接口 是 物理 的 ， 而 “端口 " 却 是 一 种 抽象 的 软件 结构 ， 包 括 一 些 数据 结 
构 和 IO (输入 /输出 ) 缓冲 区 ， 故 属于 软件 接口 范畴 ， 是 传输 层 TSAP 
地 址 。 


每 个 端口 都 拥有 一 个 称 为 "端口 号 ”的 整数 描述 符 ， 用 来 标识 不 同 
的 端口 或 进程 。 在 TCP 数 据 段 格式 中 ， 分 别 定义 一 个 16 比 特长 度 的 “ 源 
端口 ?和 “目的 端口 ?两 个 字段 ， 也 就 是 说 ， 可 定义 216 个 端口 ， 其 端口 号 
为 0~216 -1 (65535) 。 由 于 TCP/IP 传 输 层 中 的 TCP 和 UDP 是 两 个 完全 独 
立 的 软件 模块 ， 因 此 各 自 的 端口 号 也 相互 独立 ， 即 各 自 可 独立 拥有 
65535 个 端口 。 每 种 应 用 层 服务 或 应 用 进程 都 具有 与 传输 层 唯一 连接 的 
端口 ， 并 且 使 用 唯一 的 端口 号 进行 区 分 。 


可 以 将 这 65535 个 TCP 端 口 分 为 以 下 三 大 类 (它们 是 由 IANA 管理 
的 ) 。 


(1) 保留 端口 


通常 将 0~1023 号 TCP 端 口 保留 ， 因 此 ， 这 类 端口 也 称 为 “常规 端 
口 ”*， 或 者 “公认 端口 ” (well-known port) 。 这 些 端口 基本 上 都 已 固定 


地 分 配给 了 已 知 的 网 络 应 用 协议 ， 如 HITP 〈 对 应 WWW 服 务 ) 中 的 80 
号 端口 、Telnet 协 议 中 的 23 号 端口 、SMTP 中 的 25 号 端口 等 。 目 前 ， 这 
一 类 端口 的 端口 号 分 配 已 经 被 广大 网 络 应 用 者 接受 ， 形 成 了 标准 ， 在 
各 种 网 络 的 应 用 中 调用 这 些 端口 号 就 意味 着 使 用 它们 所 代表 的 应 用 协 
议 ， 因 此 不 能 被 分 配给 其 他 网 络 应 用 协议 使 用 。 表 10-7 显 示 了 部 分 常规 
服务 TCP 端 口 及 所 对 应 的 服务 。 


表 10-7 部 分 常规 服务 TCP 端口 


端口 号 对 应 的 协议 用 途 说 明 
20 FTP 数据 传输 
21 T FTP 控制 消息 
22 S 安全 登录 
23 Telnet 远程 登录 
25 SMTP 邮件 发 送 


上 
iD 


DC 
S 
nnn| 
之 二 
吕 世 | 吕 | 已 


WINS 


69 TFTP 
79 Finger 
HTTP (或 WW 
110 POP3 
L114 SFTP 
119 NNTP 
137 NetBIOS 
138 NetBIOS 
139 NetBIOS 
143 IMAP 
500 ISAKMP 


(2) 动态 分 配 端 口 


W) 


Internet 名 称 解 析 服 务 
域名 解析 

小 型 文件 传输 协议 
查询 有 关 用 户 的 信息 

万 维 网 服务 

邮件 接收 服务 

简单 文件 传输 协议 
UESNET 新 闻 

NetBIOS 名 称 服务 
NetBIOS 数据 报 服 务 
NetBIOS 会 话 服 务 
邮件 消息 管理 

Internet 安全 关联 和 密 钥 管 理 
基于 距离 矢量 的 动态 路 由 


动态 分 配 端口 的 端口 号 一 般 都 大 于 1024， 它 们 没有 分 配给 固定 的 
网 络 应 用 服务 ， 因 此 ， 可 以 动态 地 分 配给 任意 网 络 服务 应 用 程序 使 
用 。 也 就 是 说 ， 在 使 用 网 络 应 用 软件 访问 网 络 时 ， 网 络 应 用 软件 可 以 
向 系统 申请 一 个 大 于 1024 的 端口 临时 代表 这 个 软件 与 传输 层 交 换 数 
据 ， 并 且 使 用 这 个 临时 的 端口 与 网 络 上 的 其 他 主机 通信 。 


注意 ， 动 态 分 配 端 口中 有 许多 是 被 木马 类 的 墨客 程序 所 利用 的 ， 
通过 得 看 茶 个 端口 是 否 被 占用 束 可 以 了 解 当前 系统 中 坪 否 中 了 某 一 种 
木马 程序 。 


(3) 注册 端口 


注册 端口 比较 特殊 ， 它 也 是 固定 为 某 个 应 用 服务 的 端口 ， 但 是 
所 代表 的 不 是 已 经 形成 标准 的 应 用 层 协议 ， 而 是 某 个 软件 厂商 开发 的 
应 用 程序 ， 如 CCProxy 中 的 8080 号 端口 。 这 类 注册 端口 的 端口 号 一 般 也 
都 大 于 1024。 


当 网 络 中 的 两 台 主 机 进行 通信 时 ， 为 了 表明 数据 是 由 源 端 的 哪 一 
种 应 用 发 出 的 ， 以 及 数据 所 要 访问 的 是 目的 器 的 哪 一 种 服务 ，TCP/IP 
会 在 传输 层 封装 数据 段 时 ， 把 发 出 数据 的 应 用 程序 的 端口 作为 源 端 
口 ， 把 接收 数据 的 应 用 程序 的 端口 作为 目的 端口 ， 添 加 到 数据 段 的 头 
部 中 ， 从 而 使 主机 能 够 同时 维持 多 个 会 话 的 连接 ， 使 不 同 应 用 程序 的 
数据 不 会 发 生 宴 清 。 


10.3.5” TCP 连接 的 状态 转移 


从 表 10-6 中 可 以 看 出 ，TCP Socket 服 务 原 语 只 有 8 个 ， 比 OSIURM 体 
系 结构 中 定义 的 传输 层 服务 原 语 还 要 少 ， 但 是 在 这 8 种 TCP Socket 服 务 
原 语 中 ， 有 的 原 语 又 可 以 有 不 同 的 状态 ， 如 表 10-8 所 示 “。 我 们 把 在 TCP 
传输 连接 的 建立 和 释放 过 程 中 的 通信 双方 主机 的 这 些 状态 称 为 “有限 状 
态 机 ” (Finite State Machine，FSM) 。 下 面具 体 前 述 一 下 在 TCP 传 输 连 
接 建立 、 释 放 过 程 中 的 这 些 原 语 状态 的 变化 。 


表 10-8 TCP 连接 状态 


状态 描 述 
CLOSED 呈 阻 塞 、 关 闭 状态 ， 表 示 主 机 当前 没有 活动 的 传输 连接 或 正在 进行 传输 连接 
LISTEN 呈 监 听 状 态 ， 表 示 服 务 器 正在 等 待 新 的 传输 连接 进入 
SYN RCVD 表示 主机 已 收 到 和 生生 但 尚未 确认 
SYN SENT 表示 主机 已 经 发 出 一 个 传输 连接 请 求 ， 等 待 对 方 确认 
ESTABLISHED 传输 连接 建立 ， 通 信和 双方 进入 正常 数据 传输 状态 
FIN WAIT 1 (主动 关闭 ) 主机 已 经 发 送 关 闭 连 接 请 求 ， 等 待 对 方 确认 
FIN WAIT 2 (主动 关闭 ) 主机 已 收 到 对 方 关闭 传输 连接 确认 ， 等 待 对 方 发 送 关 闭 传输 连接 请 求 
TIMED WAIT 完成 双向 传输 连接 关闭 ， 等 待 所 有 分 组 消失 
CLOSING 双方 同时 尝试 关闭 传输 连接 ， 等 待 对 方 确认 
CLOSE WAIT (被 动 关闭 ) 收 到 对 方 发 来 的 关闭 传输 连接 请 求 ， 并 已 确认 
LAST ACK (被 动 关闭 ) 等 待 最 后 一 个 关闭 传输 连接 确认 ， 并 等 待 所 有 分 组 消失 


图 10-38 描 述 了 TCP 通 信 主 机 在 传输 连接 建立 和 释放 过 程 中 的 各 种 
有 限 状 态 机 ， 方 框 中 表示 的 是 通信 主机 在 不 同时 期 的 状态 ， 箭 头 表 示 
状态 之 间 的 转换 ， 旁 边 的 注释 表示 状态 转换 过 程 中 所 需 进行 的 动作 
(包括 调用 Socket 服 务 原 语 以 及 TCP 数 据 段 的 发 送 和 接收 等 。 图 10- 


38 中 用 粗 线 表示 客户 端 主动 和 被 动 的 服务 器 端 连接 建立 的 正常 过 程 ， 
其 中 客户 端的 状态 转移 用 带 箭头 的 粗 实 线 表示 ， 服 务 器 端的 状态 转换 
用 带 箭头 的 粗 虚线 表示 。 带 箭头 的 细 线 表示 一 些 不 常见 的 事件 ， 如 复 
位 、 同 时 打开 、 同 时 关闭 等 。 


(开始 ) ”主动 打开 ， 调 用 CONNECT/SYN 
原 语 (第 1 次 握手 ) 
CLOSED 


被 动 打 开 ， 调 用 ; 调用 CLOSE 原 语 
LISTEN 原 语 ”上山 | 调用 CLOSE 
原 语 调用 END 原 
| 收 到 SYN， 发 送 SYN+ACK 
站 (第 2 次 担 手 ) 
收 到 SYN， 发 送 SYN+ACK 


SYN-RCVD 是 
[= 司 本 条 SYN-SENT 


~、 收 到 ACK 收 到 SYN+ACK,， 


调用 CLOSEN、 发 送 ACK) (第 3 次 握手 ) 
原 语 ,发送 “~、 
ee pe 
= = = ~ CLOSE-WAIT : 
调用 CLOSE 原 ESTABLISHED 局 包 FIN,: er 
语 ， 发 送 FIN 发 送 ACK: | 
rs) 人 | 
i : 上 调用 CLOSEQ4 锌 动 : 
mwm | 原 语 ， 发 送 ， 关闭 ， 


收 到 FIN+ACK,， 
发 送 ACK) 收 到 


ACK i: LASTACK 


: 主动 | 收 到 
; 关闭 |ACK 


收 到 FIN, : -A ot 
: A 


I 
1 


图 10-38 ”TCP 传输 连接 有 限 状 态 机 转换 流程 


每 个 连接 均 开 始 于 CLOSED 状 态 。 当 一 方 执 行 了 被 动 的 连接 原 语 
(LISTEN) 或 主动 的 连接 原 语 (CONNECT) 时 ， 它 便 会 离开 
CLOSED 状 态 。 如 有 果 此 时 另 一 方 执行 了 相对 应 的 连接 原 语 ， 连 接 便 建 
立 了 ， 并 且 状 态 变 为 ESTABLISHED。 任 何 一 方 均 可 以 首先 请 求 释放 连 
接 ， 当 连接 被 释放 后 ， 状 态 又 回 到 了 CLOSED。 


为 了 让 读 首 看 清楚 客 刻 并 和 服务 占 各 目的 状态 转移 流程 ， 我 们 先 
沿 着 融 箭 头 的 粗 实 线路 径 来 看 客户 端的 状态 转移 过 程 ， 然 后 再 沿 着 市 
箭头 的 虚实 线路 径 来 看 服务 器 的 状态 转移 过 程 。 


1) 一 开始 ， 服 务 器 应 用 层 首 先 调用 LISTEN 原 语 从 CLOSED 状 态 进 
入 被 动 打开 状态 (LISTEN) ， 等 待 客户 端的 连接 。 


2) 当 客 户 端的 一 个 应 用 程序 调用 CONNECT 原 语 后 ， 本 地 的 TCP 
实体 为 其 创建 一 个 连接 记录 并 标记 为 SYN SENT 状 态 ， 然 后 给 服务 器 发 
送 一 个 SYN 数 据 段 (SYN 字 段 置 1) 。 这 是 TCP 传 输 连 接 的 第 一 次 握 
手 


3) 服务 器 在 收 到 一 个 客户 端的 SYN 数 据 段 后 ， 其 TCP 实 体 向 客户 
端 发 送 确认 ACK 数 据 段 (ACK 字 段 置 1) ， 同 时 发 送 一 个 SYN 数 据 段 
(SYN 字 段 置 1， 表 示 接 受 同步 请 求 ) ， 进 入 SYN RCVD 状 态 。 这 是 
TCP 传 输 连 接 的 第 二 次 握手 。 


说 明 这 里 可 能 有 一 个 非 正常 事件 发 生 ， 那 就 是 如 果 此 时 服务 器 
不 想 建立 传输 连接 ， 那 么 由 其 应 用 层 调用 CLOSE 原 语 ， 向 客户 端 发 送 
一 个 FIN 数 据 段 (FIN 字 段 置 1) ， 然 后 进入 FIN WAIT 1 状态 ， 等 待 客户 
端 确认 。 当 客户 端 收 到 服务 器 发 来 的 FIN 数 据 段 后 ， 向 服务 器 发 送 一 个 
ACK 确 认 数据 段 后 进入 到 CLOSING 状 态 ， 表 示 双 方 同时 尝试 关闭 传输 
连接 ， 等 待 对 方 确认 。 在 服务 器 收 到 客户 端 发 来 的 ACK 数 据 段 后 即 进 
入 到 TIMED WAIT 状 态 ， 在 超时 后 双方 即 关 闭 连接 。 这 是 一 种 突 发 、 
非 正常 的 连接 关闭 事件 。 


4) 客户 端 在 收 到 服务 器 发 来 的 SYN 和 ACK 数 据 段 后， 其 TCP 实 体 
给 服务 絮 病 发 送 一 个 ACK 数 据 段 ， 并 进入 ESTABLISHED 状 态 。 这 是 
TCP 连 接 的 第 三 次 握手 。 


5) 服务 器 在 收 到 来 自 客 户 端的 ACK 确 认 数据 段 后 ， 完 成 整个 TCP 
传输 连接 的 全 部 三 次 握手 过 程 ， 也 进入 ESTABLISHED 状 态 。 


此 时 ， 双 方 可 以 自由 进行 数据 传输 了 。 当 一 个 应 用 程序 完成 数据 
传输 任务 后 ， 它 需要 关闭 TCP 连 接 。 假 设 仍 由 客户 端 发 起 主动 关闭 连 
接 。 

6) 客户 端 应 用 层 调用 CLOSE 原 语 ， 本 地 的 TCP 实 体 发 送 一 个 FIN 


数据 段 (FIN 字 上 段 置 1) ， 并 等 待 服务 器 的 确认 响应 ， 进 入 FIN WAIT 1 
状态 。 


说 明 这 里 又 可 能 有 一 个 非 正 常 的 事件 发 生 ， 那 就 是 客户 端 在 FIN 
WAIT 1 状态 收 到 服务 器 的 FIN 和 ACK 数 据 段 后 〈 而 不 是 像 从 FIN WAIT 
2 状态 进入 那样 只 收 到 服务 器 的 ACK 确 认 数 据 段 ) ， 向 服务 器 发 送 一 个 
ACK 数 据 段 ， 直 接 就 进入 到 TIMED WAIT 状 态 。 在 超时 后 双方 即 关 闭 
连接 。 

7) 服务 器 在 收 到 来 自 客 户 端的 FIN 数 据 段 后 ， 它 给 客户 端 返回 一 


个 ACK 数 据 段 (ACK 字 段 置 1) ， 进 入 CLOSE WAIT 状 态 。 


8) 客户 端 在 收 到 来 自 服务 器 的 ACK 确 认 数据 段 后 ， 进 入 FIN 
WAIT 2 状态 ， 此 时 连接 在 一 个 方 同 上 残 断 开 了 ， 但 仍 可 以 接收 服务 紫 
端 发 来 的 数据 段 。 


9) 当 服务 器 收 到 客户 端 发 来 的 FIN 数 据 段 时 就 知道 客户 端 已 有 数 
据 发 送 了 ， 在 本 端 已 接收 完全 部 的 数据 后 ， 也 由 应 用 层 调用 CLOSE 原 
语 ， 请 求 关闭 另 一 个 方 癌 的 连接 ， 其 本 地 TCP 实 体 癌 客 户 端 发 送 一 个 
FIN 数 据 段 ， 并 进入 LAST ACK 状 态 ， 等 行 最 后 一 个 ACK 确 认 数 据 段 。 


10) 在 客户 端 收 到 来 自 服务 器 的 FIN 数 据 段 后 ， 向 服务 器 发 送 最 后 
一 个 ACK 确 认 数据 段 ， 进 入 TIMED WAIT 状 态 。 此 时 ， 双 方 连接 均 已 
经 断 开 ， 但 TCP 实 体 仍 要 等 待 一 个 2 倍数 据 段 MSL (Maximum Segment 
Lifetime， 最 大 数据 段 生 存 时 间 ) ， 以 确保 该 连接 的 所 有 分 组 全 部 消 


失 ， 防 止 出 现 确认 丢失 的 情况 。 当 定时 郝 超 时 后 ，TCP 删 除 该 连接 记 
录 ， 返 回 到 初始 状态 (CLOSED) 。 


11) 服务 器 收 到 客户 端 最 后 一 个 ACK 确 认 数 据 段 后 ， 其 TCP 实 体 
便 释 放 该 连接 ， 并 删除 连接 记录 ， 也 返回 到 初始 状态 《CLOSED) 。 


10.3.6 ” ”TCP 传输 连接 的 建立 


TCP 是 一 个 面向 连接 的 传输 层 协议 ， 因 此 ， 无 论 哪 一 方向 的 另 一 方 
发 送 数据 ， 都 必须 先 在 双方 之 间 建 立 一 条 传输 连接 。 本 节 将 详细 讨论 
一 个 TCP 传 输 连接 是 如 何 建 立 的 。 


1 单方 主动 连接 的 TCP 迁 接 建 立 过 程 


TCP/P 体 系 结构 中 的 TCP 也 是 使 用 三 次 握手 机 制 来 建立 传输 连接 
的 ， 这 与 在 本 章 前 面 介 绍 的 OSIURM 体 系 结构 中 传输 层 为 了 避免 重复 连 
授 而 采取 的 三 次 握手 机 制 是 一 样 的 ， 具 体 流程 如 图 10-39 所 示 。 其 实 ， 
整体 过 程 在 图 10-38 中 有 全 面 的 体现 ， 这 里 只 是 单独 把 TCP 传 输 连 接 建 
立 过 程 列 出 来 而 已 。 具 体 步 又 如 下 : 


客户 端 服务 红 


(CLOSED 状态 ， (CLOSED 状态 ， 


主动 打开 ) ee 被 动 打开 ) 
2 送 SYN 溉 ， 
i A (LISTEN 状态 ) 
| SYN=1. ACK=1 接收 SYN 数据 段 ， 发 
(SYN SENT 状态 ) seq=], ack=1+1 送 SYN 数据 报 ， 序 号 


为 j， 确 认 号 为 计 1 
7 7 ls ee 

接 收 SYN+ACK 数 据 (SYN RCVD 状态 ) 

段 ， 发 送 ACK 数据 段 ， ACK=1. seq= 计 1， 


村: 1 ack=]+1 
A edly 接收 ACK 数据 


段 ， 连 接 建立 


(ESTABLISHED 状态 ) 
(ESTABLISHED 状态 ) 


图 10-39 ”TCP 传输 连接 建立 的 三 次 握手 过 程 


1) 首先 是 服务 器 初始 化 的 过 程 ， 从 CLOSED (关闭 ) 状态 开始 通 
过 顺序 调用 SOCKET、BIND、LISTEN 和 ACCEPT 原 语 创建 Socket 套 接 
字 ， 进 入 LISTEN (监听 ) 状态 ， 等 待 客户 端的 TCP 传 输 连接 请 求 。 


2) 客户 端 最 开始 也 是 从 CLOSED 状 态 开始 调用 SOCKET 原 语 创建 
新 的 Socket 套 接 字 ， 然 后 在 需要 再 调用 CONNECT 原 语 时 ， 向 服务 器 发 
送 一 个 将 SYN 字 段 置 1 (表示 此 为 同步 数据 段 ) 的 数据 段 (假设 初始 序 
号 为 i ， 主 动 打开 端口 ， 进 入 SYN SENT (已 发 送 连 接 请 求 ， 等 待 对 
方 确认 ) 状态 。 


3) 服务 器 在 收 到 来 自 客户 端的 SYN 数 据 段 后 ， 返 回 一 个 SYN 字 有 段 
置 1 (表示 此 为 同步 数据 段 ) 、ACK 字 段 置 1 (表示 此 为 确认 数据 


段 ) 、ack (确认 号 ) =i+1 的 应 答 数据 段 (假设 初始 序号 为 )) ， 被 动 打 
开端 口 ， 进 入 到 SYN RCVD 《已 收 到 一 个 连接 请 求 ， 但 未 进行 确认 ) 
状态 。 这 里 要 注意 的 是 ， 确 认 号 是 i+1， 而 不 是 i， 表 示 服 务 器 希望 接收 
的 下 一 下 数据 段 序 号 为 i+1 。 


4) 客户 端 在 收 到 来 自 服务 器 的 SYN+ACK 数 据 段 后 ， 向 服务 器 发 
送 一 个 ACK=1 (表示 此 为 确认 数据 段 )、 序 号 为 i+1、ack=j+1 的 确认 数 
据 段 ， 同 时 进入 ESTABLISHED (连接 建立 ) 状态 ， 建 立 单 向 连接 。 要 
注意 的 是 ， 此 时 序号 为 t+1， 确 认 号 为 jt+1， 表 示 客 户 端 希望 收 到 服务 器 
的 下 一 个 数据 段 的 序号 为 j+1。 


5) 服务 器 在 收 到 客户 端的 ACK 数 据 段 后 ， 进 入 ESTABLISHED 状 
， 完 成 双向 连接 的 建立 。 


ct 


连接 可 以 由 任 一 方 或 双方 发 起 ， 一 旦 连接 建立 ， 数 据 就 可 以 双 癌 
对 等 地 流动 ， 而 没有 所 谓 的 主 从 关系 。 三 次 握手 是 连接 两 应 正确 同步 
的 充分 必要 条 件 ， 因 为 TCP 建 立 在 不 可 靠 的 分 组 传输 服务 之 上 ， 报 文 可 
能 丢失 、 延 迟 、 重 复 和 乱 序 ， 因 此 协议 必须 使 用 超时 和 重 传 机 制 。 如 
果 重 传 的 连接 请 求 和 原先 的 连接 请 求 在 连接 正在 建立 时 到 达 ， 或 者 当 
一 个 连接 已 经 建立 、 使 用 和 结束 之 后 ， 某 个 延迟 的 连接 请 求 才 到 达 ， 
束 会 出 现 问 题 。 采 用 三 次 握手 协议 可 以 解决 上 述 这 些 问 题 。 如 客 刻 站 
发 送 的 ACK 数 据 段 束 是 为 了 避免 因 网 络 延迟 而 导致 的 重复 连接 ， 因 为 


这 时 客户 端 通过 检查 ACK 数 据 段 中 的 确认 号 吏 可 得 知 该 连接 请 求 是 否 
已 


经 验 之 谈 ”对比 图 10-39 和 图 10-21， 可 以 看 出 ，TCP 传 输 连 接 的 建 
立 与 OSVRM 体 系 结构 中 TCP 传 输 协议 的 传输 连接 建立 过 程 既 存在 相似 
之 处 〈 如 三 次 握手 机 制 ) ， 又 有 较 大 区 别 ， 主 要 表现 在 : (在 OSVRM 
体系 结构 中 ， 只 有 DT TPDU 和 ED TPDU 才 有 序列 号 ， 在 返回 的 确认 类 
TPDU 中 是 没有 TPDU 序 号 的 ， 因 此 ， 在 图 10-21 中 并 没有 标注 确认 
TPDU 的 序列 号 ， 而 在 TCP 传 输 连 接 中 ， 每 个 数据 段 《无 论 是 否 携带 数 
据 ) 都 有 序列 号 ， 都 需要 标示 其 对 应 的 序列 号 ，G@ 在 OSIRM 体 系 结构 
的 传输 协议 中 ， 因 为 不 同 服务 原 语 可 以 使 用 不 同 的 特定 类 型 TPDU， 所 
以 在 OSVRM 体 系 结构 的 TPDU 中 不 存在 像 TCP 数 据 段 中 的 ACK、SYN 
等 类 型 的 控制 位 。 在 TCP 中 ， 所 有 数据 段 格 式 都 是 一 样 的 ， 不 同 的 只 是 
不 同类 型 的 TCP 数 据 段 的 这 些 字段 的 取 值 不 同 ，@TCP 传 输 连 接 中 使 
用 “确认 号 ”字段 与 OSVRM TPDU 中 的 “YR-TU-NR”( 你 的 TPDU 序 列 
号 ) 字段 的 功能 是 完全 一 样 的， 都 是 显示 对 端 希 望 接 收 的 下 一 个 数据 
段 序列 号 ， 暗 示 该 号 码 前 面 的 所 有 数据 段 均 已 正确 接收 。 


2. 双 方 同 时 主动 连接 的 TCP 连 接 建 立 过 程 


正常 情况 下 ， 传 输 连 接 都 是 由 一 方 主动 发 起 的 ， 但 也 有 可 能 双方 
同时 主动 发 起 连接 ， 此 时 束 会 发 生 连 接 碰 撞 ， 最 终 只 有 一 个 连接 能 够 
建立 起 来 。 所 有 连接 都 是 由 它们 的 端点 进行 标识 的 ， 如 果 第 一 个 连接 


请 求 建立 起 一 个 由 套 接 字 (xy) 标识 的 连接 ， 而 第 二 个 连接 也 建立 了 
这 样 一 个 连接 ， 那 么 在 TCP 实 体内 部 只 有 一 个 套 接 字 表 项 。 


当 出 现 同时 发 出 连接 请 求 时 ， 两 端 儿 乎 在 同时 发 送 一 个 SYN 字 段 
置 1 的 数据 段 ， 并 进入 SYN_SENT 状 态 。 当 每 一 端 收 到 SYN 数 据 段 时 ， 
状态 变 为 SYN_RCVD， 同 时 它们 都 再 发 送 SYN 字 段 置 1、ACK 字 段 置 1 
的 数据 段 ， 对 收 到 的 SYN 数 据 段 进 行 确认 。 当 双方 都 收 到 对 方 的 
SYN+ACK 数 据 段 后 ， 便 都 进入 ESTABLISHED 状 态 。 图 10-40 显 示 了 这 
种 同时 发 起 连接 的 连接 过 程 ， 但 最 终 建立 的 是 一 个 TCP 连 接 ， 而 不 是 两 
个 ， 这 点 要 特别 注意 。 


主机 A 主机 也 
SYN=1, sedq=i SYN SENT 状 太 
(SYN SENT 状态 ) ( 状态 ) 


(SYN RCVD 状态 ) 
SYN=1; ACKR=L; 
seq=j+1, ack=1+1 


(SYN RCVD 状态 ) 


SYN=1,.ACK=1, 
seq=1i+1, ack=]+1 


(ESTABLISHED 状态 ) 
(ESTABLISHED 状态 ) 


图 10-40 同时 发 起 连接 的 TCP 连 接 建 立 过 程 


从 图 10-40 中 可 以 看 出 ， 一 个 双方 同时 打开 的 传输 连接 需要 交换 4 个 
数据 段 ， 比 正常 的 传输 连接 建立 所 进行 的 三 次 握手 多 交换 一 个 数据 
段 。 此 外 ， 要 注意 的 是 ， 此 时 没有 将 任何 一 端 称 为 客户 端 或 服务 器 ， 
因为 每 一 冰 既 是 客户 端 又 是 服务 右 。 


10.3.7“TCP 传 输 连 接 的 释放 


当 TCP 连 接 建 立 起 来 后 ， 就 可 以 在 两 个 方向 传送 数据 流 。 当 TCP 的 
网 络 应 用 进程 再 没有 数据 需要 发 送 时 ， 就 可 以 发 出 关闭 连接 命令 ， 释 
放 连 接 。TCP 是 通过 发 送 FIN 字 段 置 1 的 数据 段 来 作为 天 闭 传输 连接 的 
命令 ， 从 而 关闭 本 逆 数 据 流 的 ,但 是 本 病 仍 然 还 可 以 继续 接收 来 目 对 
端的 数据 ， 直 到 对 问 也 使 用 了 同样 的 方法 关闭 那个 方 癌 的 数据 流 为 
止 ， 这 时 整个 双方 传输 连接 整 彻 改天 闭 了 。 


1. 单 方 主动 天 财 的 TCP 连 接 释 放 过 程 


相对 TCP 传 输 连 接 建 立 的 三 次 握手 过 程 来 说 ，TCP 传 输 连 接 的 释放 
过 程 要 稍微 复杂 一 些 ， 需 要 经 过 四 次 握手 过 程 。 这 是 由 TCP 的 半 关 闭 
(half-close) 特性 造成 的 ， 因 为 这 一 个 TCP 连 接 是 全 双 工 〈“ 即 数据 在 两 
个 方向 上 能 同时 传递 ) ， 每 个 方向 必须 单独 进行 关闭 。TCP 传 输 连 接 关 
闭 的 原则 如 下 : 当 一 端 完成 它 的 数据 发 送 任务 后 束 可 以 发 送 一 个 FIN 字 
段 置 1 的 数据 段 来 终止 这 个 方向 的 数据 发 送 ， 当 男 一 端 收 到 这 个 FIN 数 
据 段 后 ， 必 须 通 知 它 的 应 用 层 “ 对 端 已 经 终止 了 那个 方 同 的 数据 传 
送 ”。 而 FIN 数 据 段 的 发 送 是 由 应 用 层 调用 CLOSE 服务 原 语 的 结 采 。 
TCP 连 接 释 放 的 四 次 握手 过 程 如 图 10-41 所 示 ， 有 具体 描述 如 下 : 


客户 端 服务 器 
(ESTABLISHED 状态 ) FIN=1. seq=m (ESTABLISHED 状态 ) 


(FIN WAIT 1 状态 ) | ACK=1. seq=n. ack=m+1l 


(CLOSE WAIT 状态 ) 


IN=1, ACK=1, 
seq=W, ack=m+1 


(FIN WAIT 2 状态 ) 


ACK=1, seq=m+1. ack=wW+1 


(CLOSED 状态 ) 


(LAST ACK 状态 ) 


(CLOSED 状态 ) 


图 10-41 TCP 传 输 连 接 释 放 的 四 次 握手 过 程 


1) 一 开始 ， 通 信 双 方 都 处 于 ESTABLISHED (连接 建立 ) 状态 。 
如 果 客 户 端 认 为 数据 全 部 发 送 完了 ， 想 结束 本 次 传输 连接 ， 则 由 应 用 
层 的 对 应 应 用 进程 调用 CLOSE 服务 原 语 ， 然 后 向 服务 器 发 出 一 个 FIN 字 
段 置 1 的 数据 段 (假设 此 数据 段 的 序号 为 m) ， 客 户 端 进入 FIN WAIT 1 
状态 ， 等 待 服务 器 的 确认 。 


2) 服务 器 在 收 到 客户 端 发 来 的 FIN 数 据 段 后 ， 确 认 客 户 端 没 有 新 
的 数据 要 发 送 了 ， 回 客户 端 发 送 一 个 ACK 字 段 置 1、 确 认 号 为 m+1 的 数 
据 段 (假设 此 数据 段 序号 为 w， 服 务 器 与 客户 端的 数据 段 序号 可 以 不 一 
样 ) ， 表 示 前 面 的 数据 已 全 部 收 到 了 ， 然 后 进入 CLOSE WAIT (关闭 


等 待 ) 状态 。 与 此 同时 ， 服 务 器 的 TCP 实 体 通知 对 应 的 应 用 层 进程 ， 释 
放 从 客户 端 到 服务 右 方 巾 的 传输 连接 ， 进 入 半天 闭 状 态 。 但 此 时 服务 
妖 仍 可 以 癌 客 户 病 发 送 数 据 段 ， 客 户 问 也 可 接收 来 目 服 务 右 的 数据 ， 
而 且 这 可 能 要 持续 一 段 时 间 ， 直 人 惠 服务 紫 的 数据 也 全 部 发 送 完 为 止 。 


3) 当 客 户 端 收 到 服务 器 的 ACK 数 据 段 后 ， 进 入 到 FIN WAIT 2 状 
态 ， 进 一 步 等 待 服务 器 发 出 连接 释放 的 数据 段 。 


4) 当 服务 器 发 送 完全 部 的 数据 后 ， 其 对 应 的 应 用 进程 也 会 通知 
TCP 实 体 释 放 此 方向 的 TCP 传 输 连 接 ， 向 客户 端 发 送 FIN 字 段 置 1、 
ACK 字 段 置 1、ack=m+l (假设 此 时 的 数据 段 序 号 已 变 为 w) 的 确认 数 
据 段 。 这 时 服务 器 进入 LAST ACK (最 后 确认 ) 状态 ， 等 待 客户 端的 确 
认 。 

5) 客户 端 在 收 到 服务 器 的 FIN+ACK 数 据 段 后 ， 向 服务 器 发 送 一 个 
ACK 字 段 置 1、ack=w+1、 序 号 为 m+1 的 数据 段 ， 进 入 到 TIME WAIT 状 
态 。 但 此 时 TCP 连 接 还 没有 释放 ， 必 须 等 待 2MSL 时 间 (RFC793 建 议 设 
置 MSL 为 2 分 钟 ， 后 ， 客 户 端 才 进 入 到 CLOSED 状 态 ， 彻 底 释 放 了 TCP 


有 


6) 服务 器 在 收 到 客户 端 发 来 的 ACK 数 据 段 后 ， 也 进入 CLOSED 状 
态 ， 彻 底 释 放 连 接 。 此 时 ， 已 经 完成 整个 TCP 传 输 连 接 释 放 过 程 。 


2. 双 方 主动 天 闭 的 TCP 连 接 释 放流 程 


与 可 以 双方 同时 建立 TCP 传 输 连 接 一 样 ，TCP 传 输 连 接 关 闭 也 可 以 
由 双方 同时 主动 进行 〈 正 常情 况 下 都 是 由 一 方 发 送 第 一 个 FIN 数 据 段 进 
行 主 动 连接 关闭 ， 另 一 方 被 动 接 受 连 接 关 闭 ) ， 如 图 10-42 所 示 。 具 体 
摘 述 如 下 : 


主机 A 主机 B 
FIN=1. seq=1 7 状 太 
(FIN WAIT 1 状态 ) (FIN WAIT 1 状态 ) 


FIN=1. seq=j (CLOSING 状态 ) 


ACK=1, seq=j+1. ack=i+1 


(CLOSING 状态 ) 


(TIME WAIT 状态 ) (TIME WAIT 状态 ) 


等 待 2MSL 等 待 2MSL 


(CLOSED 状态 ) (CLOSED 状态 ) 


图 10-42 ”同时 主动 关闭 TCP 连 接 的 流程 


当 两 端 对 应 的 网 络 应 用 层 进 程 同 时 调用 CLOSE 原 语 ， 并 发 送 FIN 数 
据 段 执行 关闭 命令 时 ， 两 端 均 从 ESTABLISHED 状 态 转变 为 FIN WAIT 1 
状态 。 任 意 一 端 收 到 对 端 发 来 的 FIN 数 据 段 后 ， 其 状态 均 由 FIN WAIT 1 
转变 到 CLOSING 状 态 ， 并 发 送 最 后 的 ACK 数 据 段 。 当 收 到 最 后 的 ACK 
数据 段 后 ， 状 态 转 变 为 TIME_WAIT， 在 等 待 2MSL 后 进入 到 CLOSED 
状态 ， 最终 释 放 整 个 TCP 传 输 连接 。 


10.4 ”TCP 的 可 靠 传输 


本 章 前 面 一 直 在 说 TCP 是 一 个 可 以 提供 可 靠 数 据 传输 的 传输 层 协 
议 ， 那么 它 到 故 是 如 何 来 保障 可 靠 传 输 的 呢 ? 下 面 进行 具体 的 分 析 。 


在 TCP 可 靠 传 输 方面 ， 主 要 采用 以 下 4 种 机 制 : 


口 一 是 “ 字 世 编号 机 制 ”。TCP 数 据 段 以 字 节 为 单位 对 数据 段 中 
的 “数据 ”部 分 进行 一 一 编号 ， 确 保 每 个 子 市 的 数据 都 可 以 有 序 传送 和 
接收 。 


口 二 是 “数据 段 确认 机 制 ”。TCP 要 求 每 接收 一 个 数据 段 都 必须 由 
接收 端 向 发 送 端 返回 一 个 确认 数据 段 (可 以 用 一 个 确认 数据 段 一 次 确 
认 前 面 多 个 数据 段 }) ， 其 中 的 “确认 号 ?表明 了 接收 端 已 正确 接收 的 数 
据 段 序号 (“确认 号 ”前 面 的 所 有 数据 段 )。 


口 三 是 “超时 重 传 机 制 *。 在 TCP 中 有 一 个 重 传 定时 器 
(Retransmission Timer，RTT) ， 在 发 送 一 个 数据 段 的 同时 也 启动 了 
该 定时 器 。 如 果 在 定时 器 过 期 之 前 该 数据 段 还 没有 被 对 方 确认 的 话 ， 
则 定时 器 停止 ， 然 后 重 传 对 应 序号 的 数据 段 。 


四 是 “选择 性 确认 (Selective ACK，SACK) 机 制 ”。 在 SACK 支 
持 下 ， 仪 可 以 重 传 忠 少 部 分 的 数据 ， 而 不 会 重 传 那些 已 正确 接收 的 数 


据 。 


以 上 所 说 的 “ 字 节 编号 机 制 * 比 较 好 理解 ， 因 为 古 按 字 市 进行 编号 
的 ， 所 以 接收 站 根据 所 接收 到 的 数据 段 中 的 序号 束 可 知道 前 面 是 否 还 
有 数据 没 接收 到 ， 数 据 可 以 按 顺 序 同 应 用 进程 提交 ， 在 对 经 过 了 数据 
段 的 数据 进行 重组 时 也 可 以 根据 这 个 序号 进行 正确 的 重组 。 本 节 重 点 
介绍 后 面 3 种 机 制 。 


10.4.1 _TCP 的 数据 段 确认 机 制 


1. 儿 个 重要 概念 的 理解 


为 了 更 好 地 理解 TCP 的 确认 机 制 ， 下 面 回顾 一 下 与 TCP 确 认 机 制 
密切 相关 的 一 些 重 要 概念 。 


(1) 数据 段 


数据 段 指 TCP 对 从 应 用 层 接 收 的 数据 进行 分 割 所 得 到 的 数据 块 
(也 可 以 是 没有 经 过 分 割 的 整个 数据 报 文 ， 只 要 它 的 大 小 在 MSS 之 
内 ) ， 通 常 包括 二 个 以 上 字 节 ， 而 且 必 须 是 整数 倍 字 市 数 。 正 因 如 
此 ，TCP 发 送 的 是 字 节 流 ， 而 不 古 通 第 所 说 的 报 文 流 ， 因 为 在 TCP 数 
据 段 中 没有 报 文 边界 。 


(2) 序号 


TCP 发 送 的 数据 段 中 “数据 ”部 分 〈 不 包括 TCP 数 据 段 头 部 ) ， 
个 字 节 都 有 一 个 序号 ， 每 个 数据 段 中 的 “序号 ?字段 是 以 该 数据 段 中 第 
一 个 凶 节 的 序号 进行 填充 的 * 


(3) 窗口 大 小 


窗口 大 小 是 本 端 要 告诉 对 端 当前 可 以 接收 的 数据 量 ， 也 暗示 着 对 
端 此 时 可 以 一 次 性 发 送 的 数据 大 小 ， 以 字 和 为 单位 ， 但 这 里 仅 征 针对 
数据 段 中 的 “数据 ”部 分 ， 不 包括 TCP 数 据 段 头 部 ， 因 为 数据 段 到 了 对 
端的 应 用 层 后 仅 提交 “数据 ”部 分 。ITCP 可 以 一 次 性 连续 发 送 窗口 大 小 
的 数据 (但 实际 上 发 送 数 据 的 大 小 还 会 受 当前 可 用 的 “发 送 窗口 大 
小 ”影响 ) ， 其 中 包括 一 个 或 多 个 TCP 数 据 段 。 但 窗口 大 小 必须 小 于 对 
应 网 络 中 MTU (最 大 传输 单元 ) 值 大 小 ， 否 则 到 了 数据 链 路 层 还 是 要 
进行 数据 分 割 的 。 同 时 要 注意 的 是 , “窗口 大 小 "字段 是 随 痢 接收 端 可 
用 “接收 窗口 大 小 ”变化 而 变化 的 ， 不 是 固定 的 。 


注意 “无 论 是 发 送 端 ， 还 是 接 收 庙 ， 都 分 别 有 “ 发 送 袜 口 ?和 "接收 
窗口 ”> 这 两 个 窗口 ， 其 大 小 分 别 为 用 于 发 送 数据 和 接收 数据 的 缓存 大 
小 。 这 两 个 缓存 的 物理 大 小 对 于 具体 的 主机 来 说 是 固定 不 变 的 ， 除 非 
人 为 扩展 物理 内 存 ， 否 则 不 会 再 扩大 ， 只 能 沿 着 缩小 的 方向 进行 变 
化 » 


(4) 确认 号 


确认 瑟 指 发 送 包 含 这 个 “确认 写 ” 的 数据 段 的 一 端 期 望 接 收 为 一 端 
的 下 一 个 数据 段 的 起 始 序 号 。 同 时 也 上 暗示 了 在 此 序号 前 的 所 有 字 节 数 
据 均 已 正确 接收 。 


(5) ACK 


ACK 是 一 个 表明 “确认 号 ”字段 是 否 有 效 的 标志 位 。 只 有 ACK 字 上 段 
的 值 为 1， 数 据 段 中 的 “确认 号 ” 才 有 意义 ， 否 则 数据 段 中 的 “确认 号 ” 没 
有 意义 ， 即 不 具有 上 面 所 说 的 “确认 号 "含义 ， 因 为 TCP 通 常 不 会 针对 
单个 数据 段 进行 确认 ， 而 是 一 次 性 对 多 个 连续 数据 段 进 行 确 认 。 只 需 
要 对 最 近 收 到 的 那个 数据 段 进行 确认 ， 即 表明 前 面 所 有 数据 段 均 已 正 
确 接收 。 


2.TCP 确 认 机 制 的 特性 


除了 要 理解 以 上 几 个 重要 概念 外 ， 还 需要 对 TCP 确 认 机 制 的 以 下 
重要 特性 进行 正确 理解 。 


(1) TCP 可 一 次 连续 发 送 多 个 数据 段 


TCP 不 需要 等 待 接 收 对 方 发 送 的 确认 数据 段 (“ACK” 字 段 为 1 的 数 
据 段 ) 就 可 以 一 次 性 连续 发 送 多 个 数据 段 ， 这 样 可 大 大 提高 数据 发 送 
效率 。 但 一 次 性 可 发 送 多 少 个 数据 段 是 受 对 方 返回 的 “窗口 大 小 ”字段 


值 和 当前 可 用 ?发 送 窗 口 ” 大 小 双重 限制 的 。 因 为 发 送 端 对 还 没有 收 到 
确认 的 数据 段 要 进行 缓存 ， 这 需要 占用 一 定 的 “发送 窗口 ?大 小 。 


假设 发 送 端的 物理 “发 送 窗口 ?和 接收 端的 物理 “接收 窗口 ?大 小 均 
为 2000 字 节 ， 设 每 个 数据 段 大 小 为 100 字 节 ， 而 接收 端 返回 的 数据 段 中 
显示 “窗口 大 小 ?字段 值 也 为 2000， 同 时 发 送 端 此 时 的 “发 送 窗口 ?还 有 
两 个 数据 段 (200 字 节 ) 的 数据 没收 到 确认 ， 则 此 时 发 送 端 可 发 送 的 数 
据 段 数量 为 18 (2000/100-2) ， 即 1800 字 节 ， 不 能 发 送 全 部 的 2000 字 
节 数 据 。 


如 果 接 收 端 返 回 的 数据 段 中 显示 的 “窗口 大 小 ” 值 为 1000， 则 此 时 
发 送 端 可 以 1000 字 节 数 据 ， 因 为 所 发 送 的 1000 字 太 数 据 ， 再 加 上 原来 
还 没收 到 确认 的 200 字 市 数据 ， 小 于 发 送 端 的 物理 “发 送 窗口 ”大 小 
2000。 


(2) 仪 对 连续 接收 的 数据 段 进行 确认 


返回 的 确认 数据 段 中 的 “确认 号 ”字段 值 仅 代表 对 端 已 正确 接收 的 
连续 数据 段 (最 高 字 节 序号 +1) ， 而 不 一 定 是 已 正确 接收 数据 段 中 
的 “最 高 序号 +1”"， 因 为 中 间 可 能 还 有 些 数据 段 因 为 网 络 延 迟 而 暂时 未 
收 到 ， 或 出 现 了 传输 错误 而 丢失 了 。 


假设 每 个 数据 段 的 长 度 大 小 均 100 字 节 ， 接 收 端 收 到 了 序号 为 1、 
101、201、401 四 个 数据 段 。 其 中 序号 为 301 的 数据 段 和 暂时 没收 到 ， 此 . 


时 接收 端 返 回 的 确认 数据 段 中 的 “确认 号 ”只 能 是 301， 而 不 会 是 501， 

也 就 是 只 对 前 三 个 数据 段 进 行 确认 ， 不 会 对 后 面 的 401 数 据 段 进行 确 

认 ， 因 为 中 间 的 301 数 据 段 还 没收 到 。 当 后 面 收 到 了 301 数 据 段 后 ， 可 
能 会 返回 一 个 “确认 号 ”为 501 的 数据 段 ， 这 时 束 代 表 301 和 401 数 据 段 均 
己 正 确 接收 了 。 


(3) 不 连续 序号 的 数据 将 先 缓存 


当主 机 接收 到 的 数据 段 序号 不 连续 时 ， 不 连续 部 分 不 会 向 应 用 层 
的 应 用 进程 进行 提交 ， 而 十 先 缓存 在 “接收 窗口 "中 ， 等 等 接收 到 中 断 
的 序号 的 数据 段 后 再 一 起 提交 。 这 时 ， 尽 管 接收 端 已 正确 接收 了 某 坚 
数据 ， 但 仍 不 能 及 时 间 应 用 层 提交 ， 需 要 占用 “接收 窗口 ”空间 。 对 于 
没有 按 先后 次 序 正确 接收 的 数据 ， 在 癌 应 用 层 提 交 时 会 重新 按 数据 段 
序号 进行 组 合 ， 然 后 再 提交 给 应 用 层 。 


10.4.2 TCP 的 超时 重 传 机 制 


“超时 重 传 "是 TCP 保 证 数据 可 靠 性 的 另 一 个 重要 机 制 ， 其 原理 是 
在 发 送 某 一 个 数据 段 以 后 就 开启 一 个 超时 重 传 计时 器 (Retransmission 
Timer，RTT) 。 如 果 在 这 个 定时 器 时 间 内 没有 收 到 来 自 对 方 的 某 个 数 
据 段 的 确认 ， 发 送 端 启 动 重 传 机 制 ， 重 新 发 送 对 应 的 数据 段 ， 直 到 发 
送 成 功 为 止 。 需 要 注意 的 是 ， 并 不 是 RTT 定 时 器 一 到 ， 就 会 立即 重 传 
数据 ， 毕 竟 从 “发 送 窗口 "缓存 中 找到 对 应 的 数据 段 ， 然 后 安排 重新 发 
送 都 是 需要 时 间 的 ， 实 际 上 ， 超 时 重 发 的 时 间 间 隔 (Retransmission 
Time Out) 要 大 于 RTT 值 。 


1.SRTT 的 计算 


这 里 涉及 两 个 重要 问题 : 一 是 如 何 确定 RIT 值 ， 另 一 个 是 如 何 计 
算 RIO 值 。 表 面 上 看 起 来 RIT 值 容易 确定 ， 因 为 它 束 是 一 个 数据 段 往 
返 发 送 端 和 接收 着 的 时 间 总 和 ， 但 在 TCP 通 信 中 ， 中 间 可 能 经 过 了 多 
个 性 能 不 一 样 的 网 络 ， 而 且 不 同时 刻 网 络 的 拥塞 程度 可 能 不 一 样 ， 这 
台 造 成 不 同 数据 段 的 RTT 时 间 并 不 一 致 ， 甚 至 波动 非常 大 。 但 TCP 必 
须 适 应 这 种 情况 ， 必 须 能 动态 地 跟踪 这 些 变化 并 相应 地 改变 其 超时 重 
传 时 间 。 


正 因为 RTT 值 不 是 固定 的 ， 所 以 就 出 现 了 平 消 RTT (SRTT) 的 概 
念 ， 就 是 在 充分 考虑 历史 RTT 值 的 情况 下 所 设计 的 一 个 RTT 值 计算 公 
式 。 在 最 初 的 RFC793 中 ，SRTT 的 计算 公式 如 下 : 


SRTT (新 的 SRTT) =aSRTT 〈 旧 的 SRTT 值 ) + (1-a) RTT (新 的 
RTT 样 本 值 ) 


SRTT 的 初始 值 就 是 第 一 个 RTT 值 。 这 里 的 a 是 一 个 平滑 因子 ,， 它 
决定 了 旧 的 SRTT 值 所 占 的 权重 ，0<a <1。RFC2988 推 荐 的 a 典型 值 为 
0.125。 如 果 a 很 接近 0， 则 表示 新 的 SRIT 值 与 日 的 SRTT 值 很 接近 ， 变 
化 不 大 ， 相 反 ， 则 表示 变化 比较 大 。 显 然 ， 用 这 种 方法 计算 得 出 的 各 
个 时 刻 的 SRTT 值 更 加 平滑 ， 更 加 接近 当时 的 网 络 环 境 。 


2.RTO 的 计算 


虽然 可 以 通过 公式 计算 出 SRTT 值 ， 但 是 RTO 的 得 出 仍 不 古 一 件 简 
单 的 事 ， 因 为 到 底 古 RTT 定 时 器 到 后 就 重 传 ， 还 是 要 再 等 竺 多 长 时 间 
才 重 传 ， 这 是 必须 要 考虑 的 。 正 常情 况 下 ，TCP 使 用 b SRTT 作 为 重 传 
超时 间隔 (b>>1) ， 而 且 最 初 的 值 总 为 2 〈 也 就 是 在 两 倍 SRTT 时 间 后 
还 没收 到 对 应 数据 段 的 确认 才 重 传 该 数据 段 ) 。 


但 经 验 表 明 ， 采 用 第 数 的 b 值 不 够 灵活 。 于 是 ， 在 1988 年 ， 
Jacobson 提 出 使 用 平均 偏 莽 作为 标准 偏差 ( 束 古 b SRIT) 的 新 估计 算 
法 ， 要 来 维护 男 一 个 被 平 六 的 偏差 RTTD。 当 一 个 确认 数据 段 到 达 


上 时， 可 以 得 出 SRRT 和 新 的 RTT 样 本 值 之 间 的 偏差 RTTp = (SRTT- 
RTT) 。 第 一 次 测量 时 ，RTTD 为 测量 到 的 RTT 样 本 值 的 一 半 ， 在 以 后 
的 测量 中 按照 以 下 公式 进行 计算 : 


RTTD (新 的 RTTn ) =aRTTD ( 旧 的 RTTp ) + (1-a) x (SRTT- 
RTT) 


这 里 的 a 可 能 与 计算 SRTT 时 的 值 相同 ， 也 可 能 不 同 ， 通 常 取 值 为 
0.25。SRTT 是 平滑 RTT 值 ，RIT 是 新 的 RIT 样本 值 。 虽 然 RTTD 并 不 能 
完全 等 同 于 标准 偏差 .但 已 能 足够 地 反映 SRTT 值 的 动态 变化 。 现 在 大 
多 数 TCP 实 现 都 是 使 用 这 个 算法 ， 并 且 将 超时 重 传 时 间 设 置 为 : 


RIO=SRTT+4xRTTY, 


这 里 有 一 个 重要 的 问题 ， 那 就 是 对 于 重 传 的 数据 段 如 何 计 算 其 
RITT 值 。 假 设 发 送 端 发 送 了 一 个 数据 段 ， 但 在 重 传 定 时 融 内 没有 收 到 
该 数据 段 的 确认 数据 段 ， 于 是 重新 发 送 该 数据 段 ， 可 是 过 了 一 段 时 
间 ， 发 送 端 又 收 到 了 该 数据 段 的 确认 数据 段 。 这 时 发 送 端 承 “ 迷 
糊 " 了 ， 这 个 确认 数据 段 到 展 是 对 原来 发 送 的 那个 数据 段 的 确认 ， 还 坪 
对 重 发 的 数据 段 的 确认 呢 ? 这 两 个 数据 段 的 序号 是 一 样 的 ， 如 采 在 上 
次 发 送 数据 段 后 没有 再 重 痢 发送 新 的 数据 段 的 话 ， 接 收 端 返回 的 确认 
数据 段 中 的 确认 三 都 可 能 一 样 。 如 有 果 收 到 的 确认 数据 段 是 对 重 传 数据 
段 的 确认 ， 但 却 被 发 送 端 认 为 是 对 原 数 据 段 的 确认 ， 则 这 样 计 算出 的 


SRTT 和 RTO 值 肯定 会 偏 大 ， 否 则 会 偏 小 。 为 此 ， 一 位 发 现 这 个 问题 的 
无 线 电 爱 好 者 Karn 提 出 了 一 个 建议 ， 束 是 在 计算 加 权 平 均 RTT 时 ， 只 
要 数据 段 被 重 发 了 ， 就 不 采用 其 往返 时 间作 为 计算 SRTT 和 RTO 的 样 
本 ， 这 样 得 出 的 加 权 平 均 SRTT 值 和 RTO 值 就 比较 准确 了 。 


10.4.3 ”TCP 的 选择 性 确认 机 制 


在 上 面 介 绍 的 TCP 重 传 机 制 中 ， 如 采 在 重 传 定 时 天 超时 后 仍 没 收 
到 一 个 数据 段 的 确认 ， 则 可 能 会 重 传 对 应 序号 后 面 的 所 有 数据 段 ， 
为 后 面 的 这 些 数据 段 均 暂 时 不 会 被 确认 ， 这 明显 大 大 降低 了 TCP 数 据 
传输 性 能 。 


同样 假设 每 个 数据 段 大 小 为 100 字 节 ， 接 收 端 已 收 到 1、101、 
201、401、501 这 五 个 序号 的 数据 段 ， 其 中 301 号 数据 段 没 有 收 到 。 按 
照 前 面 介绍 的 确认 机 制 ， 虽 然 401、501 这 两 个 序号 的 数据 段 均 已 收 
到 ， 但 因为 301 号 这 个 数据 段 一 直 没收 到 ， 所 以 仍然 不 能 向 发 送 端 确 
认 。 在 某 个 时 间 上 ， 如 有 果 301 号 数据 段 的 重 传 定 时 器 超时 了 ， 则 发 送 端 
肯定 会 重 传 这 个 数据 段 ， 但 毕竟 重 传 的 301 数 据 段 到 达 对 端 也 是 需要 时 
间 的 。 在 这 个 301 号 数据 段 的 重 传 过 程 中 ，401 号 ， 甚 至 501 号 数据 段 的 
重 传 定时 器 也 可 能 超时 ， 这 时 发 送 端 可 能 又 对 401 号 、501 号 这 两 个 数 
据 段 进行 重 传 。 这 样 的 重 传 显然 是 不 必要 ， 也 会 造成 接收 端 重复 接收 


401 号 、501 号 这 两 个 数据 段 。 


为 了 避免 这 种 现象 的 出 现 ， 在 RFC3517 中 出 现 了 一 种 称 为 “选择 性 
确认 ”(SACK) 的 机 制 ， 就 是 在 TCP 数 据 段 格式 的 头 部 “可 选项 ”字段 


中 添加 一 个 代表 文 持 SACK 的 选项 。 但 这 个 选项 在 不 同 的 数据 段 中 有 
不 同 的 字段 名 称 和 不 同 的 含义 。 


首先， 必须 在 建 并 TCP 传输 连接 时 的 SYN 数 据 段 中 包含 “SACK- 
Permit”(SACK 人 允许 ) 字段 选项 ， 表 示 在 今后 的 传输 中 希望 收 到 
SACK 选 项 。 然 后 ， 在 其 他 的 数据 段 中 需要 包含 “SACK” 字 段 ， 在 这 个 
字段 中 ， 会 包含 本 端 要 告诉 对 端 已 接收 到 的 不 连续 数据 段 。 原 来 的 “ 确 
认 号 ?字段 同样 有 效 ， 但 此 时 的 SACK 扩 展 选 项 也 仅 在 确认 数据 段 
(“ACK” 字 段 值 为 1 时 ) 中 才 有 效 。 


“SACK-Permit* 字 段 中 包括 Kind 〈 类 型 ) 和 Length (长 度 ) 两 个 子 
字段 ， 如 图 10-43 所 示 。Kind 字 段 值 固定 为 4， 占 8 位 ， 表 示人 允许 使 用 
SACK 扩 展 确 认 选 项 ，Length 字 段 的 值 回 定 为 2， 占 8 位 ， 表 示 在 SYN 数 
据 段 中 SACK 人 允许 扩展 选项 占 2 字 节 。 


0 了 15 位 
Kind Length 
10-43” ”SYN 数据 段 中 的 “SACK-Permit” 选 项 格式 


在 其 他 非 SYN 数 据 段 的 “SACK” 字 段 中 ， 包 括 Kind、Length， 以 及 
各 不 连续 数据 段 的 起 始 字 节 号 和 结束 字 节 号 ， 如 图 10-44 所 示 。Kind 字 


段 固 定 值 为 5， 占 8 位 ， 表 示 这 是 非 SYN 数 据 段 的 SACK 选 项 ，Length 字 


段 值 可 变 ， 占 8 位 ， 以 字 和 为 单位 表示 SACK 扩 展 选项 的 长 度 。 后 面 是 
n 个 标识 不 连续 数据 段 起 始 和 结束 序号 的 部 分 ， 每 个 序号 占 32 位 。 


0 7 15 位 


Kind Length 


Left Edge of 1st Block (32 位 ) 


Right Edge of 1st Block (32 位 ) 


Left Edge of nth Block ( 32 位 ) 


Right Edge of nth Block ( 32 位 ) 


10-44 ”其 他 数据 段 中 的 “SACK” 选 项 格式 


由 于 TCP 数 据 段 头 部 的 “可 选项 ”字段 最 长 为 40 字 节 ，Kind 和 
Length 这 两 部 分 一 共 占 了 2 字 节 ， 而 表示 一 个 不 连续 数据 段 的 起 始 序号 
和 结束 序号 要 占用 8 字 下 (因为 一 个 序号 占 4 字 节 ) 。 因 此 ， 实 际 上 在 
一 个 数据 段 中 最 多 可 以 标识 4 个 不 连续 数据 段 ， 因 为 标识 4 个 数据 段 的 
起 始 序号 和 结束 序号 一 共 要 用 到 32 字 节 ， 加 上 前 面 的 Kind 和 Length 这 
两 部 分 ， 就 有 34 字 节 了 “。 而 要 标识 5 个 数据 段 的 起 始 序号 和 结束 序号 ， 


则 还 要 8 守节 ， 超 出 了 “可 选项 ”字段 40 字 市 的 限制 范围 。 所 以 ， 
在 “Length” 了 于 字段 中 ， 最 大 值 其 实 整 古 34。 


发 送 病 通过 识别 接收 器 返 回 到 确认 数据 段 中 的 SACK 扩 展 先 项 整 
可 以 得 知 接收 端 已 收 到 了 哪些 不 连续 序 吕 的 数据 段 ， 这 样 发 送 端 承 可 
以 不 再 发 送 这 些 数据 段 ， 而 只 发 送 已 丢失 的 数据 段 (发 送 端 已 发 送 ， 
且 在 重 传 定时 器 超时 后 接收 问 仍 没有 收 到 的 数据 段 ) 。 


假设 接收 端 已 收 到 1、101、201、401、501 这 五 个 序号 的 数据 段 ， 
在 发 送 确 认 号 为 301 的 确认 数据 段 时 ， 在 SACK 扩 展 选项 中 标记 401 
(起 始 序号 为 401， 结 束 序号 为 500) 和 501 (起 始 序 号 为 501， 结 束 序 
号 为 600) 这 两 个 不 连续 的 数据 段 。 这 时 发 送 端 就 会 知道 ， 不 需要 再 发 
送 401 和 501 这 两 个 数据 段 了 ， 只 需 发 送 301 号 数据 段 即 可 。 这 样 大 大 节 
省 了 网 络 资源 ， 也 提高 了 数据 传输 效率 。 


10.5 ”TCP 的 流量 控制 


昌 然 “流量 控制 ?和 10.6 世 将 要 介绍 的 “拥塞 控制 "是 两 个 不 同 的 概 
念 ， 但 是 它们 之 间 还 是 有 些 关 联 的 。“ 流 量 控制 "是 基 于 通信 双方 的 数 
据 发 送 和 接收 速率 匹配 方面 考虑 的 ， 其 最 终 目 的 殉 是 不 要 让 数据 发 送 
得 太 快 ， 以 便 接 收 闪 能 够 来 得 及 接收 ， 是 一 个 链 路 两 端的 点 对 点 行 
为 。 而 “拥塞 控制 ? 则 是 基于 网 络 中 各 段 链 路 的 市 宽 和 中 间 设 备 数据 处 
理 能 力 方面 而 考虑 的 ， 不 要 使 网 络 中 出 现 数据 传输 阻塞 ， 也 就 古 不 要 
让 发 送 端 发 送 的 数据 大 于 接收 闯 数 据 处 理 能 力 ， 是 一 个 端 到 端的 行 
为 。 但 流量 控制 又 可 能 对 拥塞 控制 有 所 大助， 其 实 解决 好 TCP 连 接 所 经 
过 的 所 有 链 路 的 流量 控制 问题 ， 也 束 基 本 上 解决 了 拥塞 控制 问题 了 。 
本 节 先 介绍 TCP 的 流量 控制 。 


10.5.1 ”TCP 的 流量 控制 简 介 


TCP 的 流量 控制 是 采用 滑动 窗口 协议 来 进行 的 。 而 在 本 章 前 面 已 提 
到 过 ，TCP 数 据 段 是 以 字 万 为 单位 进行 编号 的 ， 但 由 于 一 个 数据 段 只 有 
一 个 TCP 头 部 ， 所 以 TCP 挟 以 数据 段 为 单位 进行 传输 的 ， 接 收 端 通过 
TCP 头 部 来 识别 所 接收 的 数据 属于 哪个 数据 段 。 一 个 数据 段 只 要 没有 完 
全 接收 ， 接 收 问 整 不 会 认为 已 接收 了 该 数据 段 ， 束 像 我 们 平时 通过 QQ 
等 工具 传输 文件 时 ， 只 要 还 有 部 分 没 接 收 完 ， 则 我 们 的 计算 机 束 不 会 


认为 该 文件 已 正确 接收 ， 即 使 已 有 了 文件 名 ， 也 打 不 开 已 接收 的 部 


1. 正 芝 情 况 下 的 衫 动 窗口 流量 控制 机 制 


在 本 章 前 面 已 提 到 过 ， 在 通信 双方 主机 上 都 分 别 有 一 个 “发 送 窗 
口 ? 和 一 个 “接收 窗口 ”。 其 窗口 大 小 又 分 为 “物理 窗口 大 小 "和 * 可 用 窗口 
大 小 ”两 种 。 对 于 一 台 具 体 的 主机 来 说 , “物理 窗口 大 小 ” 值 是 固定 的 ， 
要 视 对 应 主机 所 配置 的 缓存 大 小 而 定 ; 而 “可 用 窗口 大 小 ” 值 是 可 变 
的 ， 一 端 会 根据 男 一 端的 “接收 窗口 * 大 小 (会 在 每 个 数据 段 的 “窗口 大 
小 ”字段 中 设置 ) 调整 本 端的 “发 送 窗口 大 小 "， 也 就 是 说 ，TCP 的 可 
用 “发 送 窗 口 大 小 ”是 在 不 断 变化 的 ， 而 不 是 固定 的 ， 这 也 说 明了 TCP 每 
次 发 送 的 数据 段 数 ( 即 数 据 大 小 ) 可 能 都 不 一 样 。 而 可 用 “接收 窗 
口 ”* 大 小 也 会 因 向 已 发 送 确 认 的 数据 段 数量 和 所 接收 到 的 不 连续 序号 数 
据 段 数量 (因为 已 接收 但 不 是 连续 序号 的 数据 段 是 仍 需 要 缓存 在 物 
理 “ 接 收 窗口 ?中 的 ) 而 在 不 断 变化 。 下 面 以 一 个 具体 的 示例 来 介 
绍 “TCP 滑 动 窗口 机 制 ”。 


图 10-45 是 一 个 滑动 窗口 示例 ， 其 中 的 序号 为 每 个 数据 段 的 序号 ， 
也 就 是 对 应 数据 段 的 第 一 个 字 节 序号 。 现 假设 每 个 字段 的 大 小 为 100 字 
《这 仅 是 为 了 方便 介绍 ， 实 际 的 数据 段 大 小 一 般 都 在 干 个 字 节 以 
上 ) ， 物 理发 送 窗口 ?大 小 为 500 字 节 (这 也 是 为 了 方便 介绍 ， 实 际 的 
窗口 大 小 远大 于 这 个 值 ) 。 


已 发 送 但 未 被 确认 等 待 发 


1 | 1101 201 | 301 ， ' 401 S01 601 ， 701 | 801 ， 1 901 


eT 


| 1001 ， 1101 11201 1301 ， 11401 1501 


a 


已 发 送 且 已 被 确认 


图 10-45” TCP 滑动 窗口 示例 


1) 首先 假设 现在 发 送 端 收 到 了 接收 端 发 来 的 一 个 确认 数据 
段 , “确认 号 ?为 301, “窗口 大 小 ”为 500， 表 示 可 以 连续 发 送 5 个 数据 段 
(起 始 序 号 为 301) 。 左 边 那 个 虚线 “发 送 窗口 ”代表 的 就 是 后 面 发 送 的 
301、401、501、601、701 这 五 个 数据 段 ， 此 时 因为 已 达到 了 对 方 窗口 
大 小 值 ， 不 能 继续 发 送 了 ， 需 要 停 下 来 等 待 对 端的 确认 。 


2) 如 果菜 一 时 间 收 到 了 一 个 “确认 号 ”为 501 的 确认 数据 段 
(“ACK” 字 段 值 为 1 的 数据 段 ， 下 同 ) ， 表 示 接 收 端 已 正确 接收 了 301 
和 401 这 两 个 数据 段 ， 即 从 “发 送 窗 口 ” 中 删除 这 两 个 数据 段 ， 窗 口 向 前 
滑动 200 字 节 (也 就 是 301 和 401 这 两 个 数据 段 的 大 小 ， 移 到 了 图 10-45 
中 细 实 线 “ 发 送 窗口 ”位置 ， 其 中 501、601 和 701 这 三 个 数据 段 是 原来 已 
发 送 但 没收 到 确认 的 缓存 数据 段 ，801 和 901 这 两 个 数据 段 才 是 要 等 待 
发 送 的 。 


假设 以 上 返回 的 确认 数据 段 中 的 “窗口 大 小 ”为 400 〈 这 里 起 到 了 流 

量 控制 的 作用 ) ， 理 论 上 说 ， 发 送 端 可 以 一 次 性 连续 发 送 4 个 数据 段 ， 

但 因为 “发 送 窗口 ”中 缓存 了 原来 已 发 送 的 501、601 和 701 这 三 个 数据 段 
(300 字 节 ) ， 于 是 此 次 只 能 发 送 100 字 节 ， 即 801 号 数据 段 。 


3) 如 果 此 时 收 到 了 一 个 “确认 号 ?为 801 的 确认 数据 段 ， 同 时 “窗口 
大 小 ”字段 值 又 为 500 了 (这 里 也 起 到 了 流量 控制 的 作用 ) ， 则 发 送 端 
知道 接收 器 已 收 到 了 701 号 及 以 前 所 有 的 数据 段 了 ， 于 是 从 “发 运 窗 
口 * 中 删除 这 些 缓存 的 数据 段 ， 此 时 实际 上 缓存 的 数据 段 仅 为 801 号 数 
据 段 。 但 原来 的 901 号 数据 段 已 在 “发 送 窗口 ?中 ， 等 待 发 送 ， 此 时 “发 送 
窗口 ”只 需要 继续 向 前 移 300 字 节 ， 也 就 是 三 个 数据 段 (此 时 假设 数据 
段 大 小 均 为 100 字 节 的 情况 下 ) ， 即 如 图 10-45 所 示 的 粗 实 线 表 示 “ 发 送 
窗口 "， 继 续 发 送 901、1001、1101、1201 这 四 个 数据 段 。 


2. 存 在 数据 丢失 情况 下 的 流量 控制 


如 采 在 数据 传输 过 程 中 有 一 个 或 多 个 数据 段 丢 失 ， 则 发 送 端 接收 
不 到 对 这 些 数据 段 的 确认 数据 段 ， 这 时 可 以 通过 上 市 介绍 的 超时 重 传 
来 解决 。 现 在 要 探讨 的 一 个 问题 是 ， 如 果 某 个 时 间 ， 对 并 发 送 的 数据 
段 显 示 “ 窗 口 大 小 "字段 值 为 0， 这 时 发 送 端 目 然 不 能 再 发 送 数据 了 ， 只 
好 等 竺 对方 发 来 一 个 “窗口 大 小 ”字段 值 不 为 0 的 数据 段 。 可 是 如 打 对 端 
发 来 的 这 个 数据 段 在 传输 过 程 中 丢失 了 ， 那 么 这 时 对 于 发 送 病 来 说 ， 
直 在 等 竺 来 目 接收 端 “窗口 大 小 "字段 值 非 0 的 数据 段 ， 而 接收 端 又 在 


等 待 发 送 端 发 来 新 的 数据 ， 因 为 它 自 己 不 知道 所 发 送 的 数据 段 在 途中 
丢失 了 (当然 这 仪 适用 于 C/S 模 式 ， 对 于 非 C/S 模 式 ， 也 就 没有 发 送 端 
和 接收 端 之 分 了 ， 双 方 都 可 以 发 送 ， 都 可 以 使 用 超时 重 传 机 制 ) 。 


束 像 你 与 你 的 朋友 约定 ， 在 条 件 满足 时 他 通过 快递 方式 给 你 寄 一 
样 东 西 ， 但 你 并 不 知道 他 具体 什么 时 候 寄 ， 他 寄 的 时 候 也 没 告诉 你 
(因为 他 只 相信 快递 公司 ) 。 而 恰好 这 件 快递 在 途中 丢失 了 ， 结 果 是 
你 一 直 在 等 待 你 的 朋友 寄 来 你 所 需要 的 东西 《你 也 不 好 意 催 问 你 的 朋 
友 是 否 寄 了 ) ， 而 你 的 朋友 一 直 在 等 待 你 收 到 的 通知 (总 认为 快递 一 
般 不 会 丢 东 西 的 ) 。 这 样 可 能 等 了 好 久 ， 你 的 朋友 才 可 能 想起 这 件 
事 ， 询 问 你 是 否 收 到 了 这 件 快递 。 


为 了 解决 这 一 问题 ，TCP 中 引入 了 一 个 称 为 “持续 计时 

器 ” (persistence timer) 的 定时 器 。 在 TCP 连 接 的 一 端 收 到 对 端的 一 
个 “窗口 大 小 ”字段 值 为 0 的 数据 段 时 ， 局 动 该 定时 器 。 在 这 个 定时 锋 到 
期 后 ， 收 到 这 个 “窗口 大 小 "字段 值 为 0 的 数据 段 的 一 端 会 问 对 端 发 送 一 
个 非常 小 的 探测 数据 段 (一 般 仅 携带 1 字 市 的 数据 ，， 这 时 ， 对 端 在 收 
到 这 个 探测 数据 段 后 会 返回 一 个 确认 数据 段 。 如 果 在 确认 字段 中 的 “ 窗 
口 大 小 ”字段 值 仍 为 0， 则 发 送 端 重启 上 面 的 “持续 计时 右 ”*"， 否 则 结合 确 
认 数 据 段 中 的 “窗口 大 小 ”字段 值 和 当前 可 用 “发 送 窗口 大小， 发 送 相 应 
字 太 的 数据 ， 打 破 以 上 这 种 双方 持续 等 行 的 局 面 。 


10.5.2 ”基于 传输 效率 的 考虑 


我 们 在 前 面 已 提 到 过 ，TCP 数 据 段 中 只 对 “数据 ”部 分 的 字 万 进行 
编号 ， 原 因 坪 在 对 方 传输 层 解 封 逆 后 得 到 ， 并 且 所 需要 的 只 是 “ 数 
据 * 部 分 内 容 ， 这 样 就 可 以 很 容易 地 知道 接收 的 数据 是 否 连续 。 否 则 ， 
如 果 加 上 TCP 数 据 报 头 ， 以 及 传输 到 网 络 层 的 IP 报 头 ， 传 输 到 数据 链 
路 层 报 头 ， 数 据 部 分 的 编号 吏 不 可 能 连续 ， 议 且 不 同 数据 段 的 报头 大 
小 都 可 能 不 一 样 ， 因 为 还 有 “可 选项 ”部 分 。 


对 于 大 型 的 数据 传输 ， 这 些 报头 加 起 来 也 才 几 十 字 节 ， 对 于 一 个 
数据 段 动 辑 上 于 个 字 节 来 说 ， 这 些 协议 头 部 分 显然 是 可 以 忽略 不 计 
的 ， 也 束 是 说 ， 传 输 效 率 是 非常 高 的 。 但 是 我 们 要 考虑 各 方面 的 应 
用 ， 如 在 一 些 交 互 式 应 用 中 ， 每 次 传输 的 数据 部 分 可 能 仅 一 个 或 几 个 
字 市 ， 如 果 为 每 个 这 样 的 数据 传输 一 次 ， 显 然 传 输 效 率 是 很 低 的 ， 因 
为 使 用 几 十 个 协议 头 而 最 终 传输 的 有 用 数据 却 仅 几 个 字 节 。 这 类 情况 
还 会 在 发 送 确认 数据 段 时 经 常 发 生 ， 如 果 仅 是 用 来 确认 的 数据 段 ， 里 
面 的 数据 量 是 非常 小 的 ， 也 正 因 如 此 ， 所 以 通常 是 在 措 带 大 量 数据 的 
数据 段 中 把 ACK 字 段 置 1， 同 时 起 到 确认 的 作用 。 


这 时 就 涉及 什么 时 候 把 这 些 数据 组 装 成 一 个 数据 段 进行 传输 的 问 
题 了 。 其 中 也 涉及 两 个 非常 重要 的 算法 : Nagle 算法 和 Clark 算 法 。 


Nagle 算 法 规定 : 如 果 数 据 每 次 以 1 字 世 的 方式 进入 到 发 送 喘 ， 则 
发 送 端 只 是 发 送 第 一 个 字 节 ， 然 后 其 余 的 字 节 先 缓存 起 来 ， 直 到 发 送 
出 去 的 那个 字 市 被 确认 为 止 。 然 后 ， 将 所 有 缓存 起 来 的 数据 放 在 一 个 
TCP 数 据 段 中 发 送出 去 ， 随 后 继续 开始 缓存 后 续 子 广 ， 直 到 全 部 发 送 
出 去 的 字 世 全 部 确认 为 止 。 利 用 这 种 算法 ， 可 以 大 大 提高 传输 效率 ， 
因为 不 会 因 1 个 字 市 而 使 用 几 十 个 协议 头 来 携 之 。 试 想 一 下 ， 例 如 ,一 
个 用 户 的 键盘 输入 很 快 ， 而 网 络 很 慢 ， 这 时 束 会 把 用 户 的 许多 次 输入 
字符 组 朔 成 一 个 数据 段 ， 然 后 一 次 发 送出 去 ， 大 大 减少 所 占用 的 网 络 
市 宽 。Nagle 算 法 还 规定 ， 当 到 达 的 数据 已 达到 发 送 窗口 大 小 的 一 半 或 
者 已 达到 数据 段 的 最 大 长 度 时 ， 也 要 发 送出 去 。 


还 有 一 种 情况 ， 发 送 端的 TCP 实 体 从 应 用 层 接收 到 大 量 的 数据 ， 
等 竺 发送， 而 此 时 接收 端的 应 用 却 每 次 只 需要 1 字 下 的 数据 ， 然 后 同 发 
送 端 发 出 确认 数据 段 ， 当 然 ， 其 中 显示 的 “窗口 大 小 "字段 值 殉 只 是 1 了 
(1 字 节 ) 。 发 送 端 收 到 确认 数据 段 后 自然 也 就 只 能 再 发 送 1 字 闻 的 数 
据 (但 其 中 的 TCP 和 IP 协 议 头 至 少 是 40 字 广 ) ， 然 后 接收 端 再 次 发 回 
针对 这 1 字 市 数据 的 确认 数据 段 。 显 然 ， 这 种 传输 方式 的 效率 也 是 很 低 
8 


为 了 解决 这 种 问题 ，Clark 近 出 了 一 种 解决 方案 ， 殉 是 栖 止 接收 端 
发 送 “ 窗 口 大 小 ”字段 值 为 1 〈 也 就 是 数据 部 分 仅 1 字 节 ) 的 数据 段 ， 即 
让 接收 端 继续 等 待 一 段 时 间 ， 使 得 接收 端的 “接收 窗口 ?有 足够 的 空间 


可 以 容纳 一 个 最 大 数据 段 长 度 的 数据 ， 或 者 它 的 缓存 空间 一 半 已 空 时 
( 取 两 者 的 最 小 值 ) 才 发 送 确认 数据 段 。 这 时 ,，“ 窗 口 大 小 字段 值 肯 
定 不 是 1 了 ， 这 样 发 送 端 就 可 以 一 次 性 发 送 更 多 的 数据 ， 从 而 提高 传输 

效率 。 


10.6 ”TCP 的 拥塞 控制 


TCP 中 最 复杂 的 功能 可 能 束 是 拥塞 控制 功能 了 ， 因 为 两 端 经 过 的 网 
络 效 量 、 网 络 类 型 、 网 络 性 能 非常 不 确定 ， 而 这 些 因 素 又 深 深 地 影 啊 
着 TCP 连 接 拥塞 控制 的 复杂 性 和 难度 。TCP 的 拥塞 控制 主要 是 依靠 TCP 
连接 双方 商定 的 协议 来 减少 数据 的 发 送 而 实现 的 。 


10.6.1_TCP 拥 塞 控 制 简介 


顾名思义 ， 拥 塞 控制 (congestion control) 就 是 要 控制 “网 络 拥 
塞 "的 出 现 。 什 么 情况 下 会 出 现 网 络 拥塞 呢 ? 简单 地 说 ， 网 络 中 各 个 前 
分 输入 的 流量 大 于 输出 的 流量 时 束 会 出 现 网 络 拥塞 。 打 一 个 比较 类 似 
的 比喻 (之 所 以 说 是 “类 似 *"， 因 为 它 更 像 “流量 控制 "类 的 比喻 ， 就 像 
在 公路 上 发 生 塞车 的 一 个 根本 原因 束 古 出 口 道路 太 罕 ， 而 入 口 道路 叉 
比较 曙 ， 导 人 致 同一 时 间 驶 入 的 车 辆 数 大 于 驶 出 的 车 辆 数 ， 最 终 使 得 这 
条 路 上 排队 并 挤 满 了 各 种 车 辆 ， 车 辆 的 行驶 速度 自然 会 降下 来 。 最 坏 
的 情况 是 什么 ， 那 束 是 完全 “ 墙 死 *"， 和 车辆 根本 出 不 去 ， 也 进 不 来 。 这 
束 关 似 网 络 中 通 音 所 说 的 “ 死 锁 ? 现 象 。 


当然 ， 道 路 上 发 生 塞车 的 原因 不 仅 只 有 上 面 所 说 的 那 一 个 ， 还 有 
像 上 游戏 入 的 车 辆 太 多 、 中 间或 下 游 正 在 进行 车 辆 检查 、 中 间 某 些 皇 


辆 行驶 速度 太 慢 ， 或 者 发 生 了 交通 事故 而 占用 了 部 分 道路 等 。 整 像 首 
路 发 生 塞车 的 原因 有 多 种 一 样 ， 网 络 上 发 生 拥 塞 的 原因 也 可 能 是 多 方 
面 的 ， 而 且 网 络 结构 越 复 洒 ， 发 生 拥 赛 的 原因 也 可 能 越 复杂 。 如 TCP 连 
接 的 整个 链 路 中 有 结 点 设备 的 绥 存 空间 太 小 、 数 据 转 发 能 力 太 低 、 菏 
段 链 路 市 充 太 小 、 对 端 数据 接收 能 力 低 等 ， 都 可 能 引起 网 络 拥塞 。 而 
且 往 往 是 多 个 因素 同时 存在 的 ， 因 此 ， 处 理 拥塞 控制 问题 不 能 简单 地 
针对 某 一 方面 来 加 以 解决 ， 必 须 从 全 局 角度 来 寻找 解决 方案 ， 否 则 可 
能 不 仅 不 能 解决 拥塞 现象 ， 反 而 会 形成 新 的 瓶 贷 ， 使 网 络 更 加 拥塞 。 


例如 ， 用 户 想 单方 面 地 提高 中 间 路 由 器 结 点 的 数据 转发 能 力 ， 而 
忽视 了 所 经 路 径 上 各 段 链 路 的 市 宽 ， 结 果 是 虽然 所 高 了 路 由 器 转发 性 
能 ， 也 提高 了 数据 转发 速度 ， 但 也 同时 造成 了 在 链 路 上 排队 前 行 的 数 
据 不 断 增 多 ， 这 样 不 仅 没 有 解决 网 络 拥塞 问题 ， 反 而 使 网 络 拥塞 得 更 
严重 。 再 如 ， 用 户 想 单方 面 地 提高 路 由 器 的 缓存 能 力 ， 但 没有 同步 考 
虑 路 由 融 的 数据 转发 能 力 和 链 路 的 市 宽 ， 结 采 是 虽然 可 以 使 更 多 的 数 
据 在 路 由 器 上 暂时 缓存 ， 但 在 缓存 中 排队 的 数据 所 需 等 待 的 时 间 会 
长 ， 因 为 队列 比 以 前 更 长 了 ， 绪 采 会 因为 超时 重 传 这 些 数据 。 重 传 数 
据 越 多 ， 网 络 负 傈 超越 重 ， 最 终 导 致 拥塞 更 加 严重 。 残 像 我 们 在 车 站 
买 票 ， 如 果 售 票 员 的 售票 速度 没有 提高 ， 仅 增加 了 用 于 排除 等 候 的 空 
间 ， 束 会 让 队列 排 得 更 长 ， 这 样 古 不 能 解决 长 时 间 排队 买 票 难题 的 ， 
有 反而 使 排 在 后 面 的 人 头 到 票 的 时 间 更 长 ， 同 时 使 得 售票 厅 更 加 拥挤 。 


如 果 把 整个 网 络 有 效 处 理 负荷 的 能 力 称 为 “吞吐 
量 ”(throughout) ， 而 把 网 络 中 发 送 端 输入 的 负荷 称 为 “输入 负 
荷 ”(input load) ， 则 理想 情况 下 它们 之 间 有 如 图 10-46 所 示 的 线性 关系 
(吞吐 量 是 呈 45* 斜 线 上 升 的 ) 。 


存 叶 量 


输入 负荷 
图 10-46 理想 情况 下 的 吞吐 量 与 输入 负 倚 之 间 的 关系 


从 岁 10-46 中 可 以 看 出 ， 在 开始 时 ， 网 络 系统 的 吞吐 量 随 春 输入 负 
谷 的 增加 呈 同 步 提 高 态势 《两 者 的 提高 量 是 一 样 的 ， 但 当 到 了 一 定 
时 期 (在 输入 负荷 达到 了 网 络 的 最 大 否 吐 量 时 ，， 输 入 负载 再 怎么 增 
加 ， 网 络 系统 的 吞吐 量 也 不 再 提高 了 ， 而 是 保持 在 一 个 不 变 的 水 平 。 
这 时 就 出 现 了 轻 度 拥 塞 现象 。 束 像 一 条 河流 最 初 是 没有 水 的 ， 当 上 游 
河流 放水 时 ， 它 的 水 速 会 随 着 上 游 流 入 水 的 水 速 提高 而 提高 ， 但 当 这 
条 河流 满 了 以 后 ， 也 就 是 到 了 它 的 最 大 负 和 三 水 平时 ， 它 的 水 速 不 会 再 


有 提高 了 ， 尺 管 上 游 流 入 的 水 速 仍 在 提高 。 从 上 游 新 增 的 那 部 分 水 哪 
里 去 了 呢 ? 肯定 是 汶 出 了 ， 就 像 网 络 达到 最 大 吞吐 量 时 ， 从 发 送 端 发 
来 的 超出 知 吐 量 那 部 分 的 数据 会 被 丢 痉 一 样 。 


图 10-46 只 是 一 种 理想 情况 ， 实 际 上 网 络 系统 知 吐 量 与 输入 负 何 之 
间 的 关系 永远 不 会 是 线性 关系 。 因 为 网 络 中 不 可 能 完全 是 理想 状态 ， 
所 以 一 开始 “吞吐 量 ” 和 “输入 负 谷 "之 间 的 关系 殉 不 是 择 线性 关系 的 。 当 
输入 负荷 达到 或 接近 最 大 否 吐 量 时 ， 如 果 继 续 提 高 输入 负荷， 此 时 网 
络 系统 的 实际 春 吐 量 是 不 会 保持 在 最 大 大 吐 量 水 平 的 ， 而 是 至 现下 降 
趋势 的 ， 如 条 此 时 输入 负 千 继续 增加 ， 那 么 最 终 可 能 导致 网 络 系统 的 
否 吐 量 下 降 到 0， 出 现 完全 死 锁 状态 ， 如 图 10-47 所 示 。 


实际 情况 下 


出 现 死 锁 


输入 负荷 
图 10-47 实际 情况 下 的 吞吐 量 与 输入 负 谷 之 间 的 天 系 


10.6.2 TCP 拥塞 控制 方案 


虽然 已 经 了 解 了 发 生 拥 塞 的 原因 ， 也 知道 了 网 络 系统 吞吐 量 与 输 

入 负 谷 之 间 的 关系 ， 但 要 真正 设计 一 僚 有 效 的 拥塞 控制 方案 却 不 是 一 
件 容 易 的 事 ， 因 为 拥塞 的 出 现 和 所 引起 的 因素 都 是 动态 的 ， 是 在 不 断 
发 生变 化 的 。 发 生 网 络 拥 寨 的 一 个 最 明显 的 征兆 就 是 出 现 了 数据 的 丢 
失 。 于 是 ， 为 了 防止 网 络 出 现 拥塞 现象 ， 出 现 了 一 系列 的 TCP 拥 塞 控制 
机 制 。 最 初 是 由 V.Jacobson 在 1988 年 的 论文 中 提出 的 TCP 的 拥 窗 控制 ， 
由 “ 慢 启 动 ”(slow start) 和 “拥塞 避免 ”congestion avoidance) 组 成 ， 
后 来 在 TCP Reno 版 本 中 又 针对 性 地 加 入 了 “快速 重 传 ” (fast 
retransmit) 、“ 快 速 恢复 ”(fast recovery) 算法 。 为 了 方便 介绍 ， 现 假 
设 数据 是 单方 面 发 送 的 ， 为 一 个 方向 只 传送 确认 数据 段 ， 而 且 假 设 接 
收 问 的 窗口 足够 大 ， 发 送 端 的 窗口 大 小 由 网 络 拥 塞 程度 决定 。 


1. 慢 启动 


慢 启 动 是 指 为 了 避免 出 现 网 络 拥塞 而 采取 的 一 种 TCP 拥 塞 初期 预防 
方案 。 其 基本 思想 就 是 在 TCP 连 接 正 式 传输 数据 时 ， 每 次 可 发 送 的 数据 
大 小 (这 就 是 “拥塞 窗口 * 的 含义 ) 是 逐渐 增 大 的 ， 也 就 是 先 发 送 一 些 
小 字 节 数 的 试探 性 数据 ， 在 收 到 这 些 数据 段 的 确认 后 ， 再 慢 慢 增加 发 
送 的 数据 量 ， 直 到 达到 了 某 个 原先 设 定 的 极限 值 (也 就 是 下 面 将 要 提 
到 的 “ 慢 启动 阔 值 ”(SSTHRESH) ) 为 止 。 


在 “ 慢 局 动 ”拥塞 解决 方案 中 ， 发 送 端 除 了 要 维护 正常 情况 下 根据 
接收 剖 发 来 的 “窗口 大 小 ”字段 值 而 调整 的 “发 送 窗 口 * 外 ， 还 要 维护 一 
个 “拥塞 窗口 ” (Congestion Window，CWND) ， 它 是 为 了 避免 发 生 拥 
塞 而 设置 的 窗口 ， 最 终 人 允许 发 送 的 字 市 数 是 这 两 个 窗口 中 的 最 小 值 。 
如 果 从 接收 端 返 回 的 “窗口 大 小 ”字段 值 是 100， 而 当时 设置 的 “拥塞 窗 
口 ? 大 小 为 50， 此 时 只 能 发 送 50 字 节 的 数据 。 相 反 ， 如 果 从 接收 端 返 回 
的 “窗口 大 小 ”字段 值 是 100， 而 当时 设置 的 “拥塞 窗口 ?大 小 为 200， 则 此 
时 只 能 发 送 100 字 万 的 数据 。 下 面 仅 假 设 “ 拥 塞 窗口 "总 是 小 于 从 接收 端 
返回 的 “窗口 大 小 ”字段 值 (也 就 是 “发 送 窗口 ?大 小 ) 。 上 有 具体 步 又 如 下 : 


1) 在 一 个 TCP 传 输 连接 建立 时 ， 发 送 端 将 “拥塞 窗口 ”初始 化 为 该 
连接 上 当前 使 用 的 最 大 数据 段 大 小 (Maximum Segment Size， 
MSS) ， 即 CWND=MSS。 然 后 它 发 送 一 个 大 小 为 MSS 的 数据 段 。 


2) 如 果 在 定时 器 过 期 前 发 送 端 收 到 了 该 数据 段 的 确认 ， 则 发 送 端 
将 “拥塞 窗口 ”大 小 再 增加 一 个 MSS， 也 就 是 此 时 CWND 大 小 为 2MSS。 
然后 发 送 2MSS 大 小 的 数据 。 


3) 如 果 这 次 发 送 的 2MSS 数 据 段 也 都 被 确认 了 ， 则 “拥塞 窗口 ”大 
小 再 增加 两 个 MSS (此 时 相当 于 达到 了 4MSS) ， 依 此 类 推 。 


图 10-48 是 一 个 采用 “ 慢 启 动 * 方 案 的 示例 ， 其 中 M 代 表 MSS， 表 
示 “ 最 大 数据 段 大 小 ”。 第 一 次 发 送 一 个 MSS ( 即 M1) ， 收 到 M1 的 确认 


后 ， 再 连续 发 送 两 个 MSS 〈 即 M2 和 M3) ， 当 收 到 M3 的 确认 (因为 后 
面 的 已 经 确认 的 话 ， 预 示 前 面 的 都 已 正确 接收 ， 下 同 ) 后 再 发 送 四 个 
MSS ( 即 M4~M7) ， 当 收 到 M7 的 确认 时 ， 后 面 将 发 送 8 个 MSS ( 即 


M8~M15) ...... 


CWND=1 发 送 M1 


确认 MI 

CWND=2 发 送 M2\M3 
确认 M3 

CWND=4 发 送 M4 ~ M7 
确认 M7 


CWND=8 发 送 M8 ~ M15 


图 10-48 “ 慢 启 动 * 解 决 方案 TCP 数 据 发 送 示例 


“ 慢 局 动 * 方 案 的 基本 规律 ， 当 “拥塞 窗口 ”大 小 达到 了 n 个 MSS 时 ， 
如 果 所 有 n 个 数据 段 都 被 及 时 确认 ， 则 新 的 “拥塞 窗口 ”大 小 再 增加 n 个 
MSS， 也 就 是 新 的 “拥塞 窗口 ”大 小 是 旧 的 “拥塞 窗口 ”大 小 的 2 倍 关 系 ， 


即 “ 拥 塞 窗口 "大 小 与 最 大 数据 段 大 小 (MSS) 的 关系 是 2 的 指数 关系 ， 
BIMSS 、2MSS 、4MSS 、8MSS 、16MSS 、32MSS...... 


但 是 “拥塞 窗口 ”不 可 能 无 限制 地 继续 增 大 ， 即 使 CWND 值 仍 小 于 
从 接收 端 返回 的 “窗口 大 小 "字段 值 ， 都 有 可 能 在 某 个 时 刻 出 现 数据 丢 
失 的 现象 。 这 个 “拥塞 窗口 ”大 小 是 一 个 临界 点 ， 于 是 引入 了 “ 慢 启 动 * 方 
案 的 男 一 个 重要 参数 一 一 “ 慢 启 动 病 值 ” (Slow Start Threshold 
SSTHRESH) ， 其 初始 值 为 64KB， 即 65535 字 节 。 当 发 生 一 次 数据 丢 
失 时 ，SSTHRESH 设 为 当前 CWND 的 一 半 ， 而 CWND 又 重新 置 为 
1MSS。 然 后 继续 使 用 * 慢 启动 ”方案 来 解决 网 络 拥塞 问题 ， 不 过 当 
CWND 再 次 增长 到 SSTHRESH (此 时 仅 为 原来 CWND 的 一 半 ) 时 便 停 
止 使 用 “ 慢 局 动 ” 方 案 ， 需 采用 下 面 将 要 介绍 的 “拥塞 避免 ?解决 方案 。 


2. 拥 塞 避免 


当 CWND 再 次 大 于 或 等 于 SSTHRESH 时 ， 启 动 * 拥 塞 避 免 ? 解 决 方 
案 。 它 的 基本 思想 是 在 CWND 值 第 二 次 达到 SSTHRESH 时 ， 让 “拥塞 窗 
口 ” 大 小 每 经 过 一 个 RTT (一 个 数据 段 往返 接收 端 和 发 送 端 所 需 的 时 
间 ) 时 间 仅 值 加 1 ( 即 新 的 CWND 只 增加 一 个 MSS 大 小 ， 而 不 是 原来 
CWND 的 几 倍 ) ， 使 其 以 线性 方式 慢 慢 地 增 大 ， 而 不 是 继续 像 “ 慢 启 
动 ”方案 中 那样 以 指数 方式 快速 增 大 。 显 然 ， 这 种 CWND 增 长 速度 明显 
要 慢 于 “ 慢 启 动 * 方 案 中 的 CWND 增 长 速度 。 当 再 次 发 生 数 据 丢失 时 ， 


会 把 SSTHRESH 减 为 当前 CWND 的 一 半 ， 同 时 把 CWND 置 为 1， 重 新 
进入 “ 慢 启 动 ” 数 据 发 送 过 程 ， 依 此 类 推 。 


图 10-49 是 一 个 “ 慢 局 动 ” 和 “拥塞 避免 ?两 种 拥塞 控制 方案 的 控制 示 
例 。 假 设 最 初 在 某 个 时 间 的 “拥塞 窗口 * 大 小 (CWND) 为 64KB， 而 就 
在 此 后 发 生 了 数据 丢失 ， 没 有 收 到 后 面 发 送 的 数据 的 确认 ， 于 是 
(SSTHRESH) 减 为 CWND 的 一 半 ， 即 32KB ( 即 图 10-49 中 的 “第 一 次 
调整 的 阔 值 ”) ， 同 时 把 新 的 CWND 设 为 1MSS， 从 坐标 原点 开始 重新 
采用 “ 慢 启动 ”方案 进行 数据 发 送 ， 当 达到 了 SSTHRESH 值 ( 即 32KB) 
时 ， 采 用 “拥塞 避免 "方案 进行 数据 发 送 ， 每 个 RTT 时 间 CWND 只 增加 一 
个 MSS。 但 在 第 11 次 传输 过 程 中 (此 时 CWND=38KB) 又 发 生 了 一 次 
数据 丢失 ， 于 是 SSTHRESH 再 次 降 为 当前 CWND ( 即 38KB) 的 一 半 
( 即 19KB) ， 并 且 重 新 开始 采用 “ 慢 启动 ”方案 发 送 数据 ， 直 到 达到 新 
的 SSTHRESH 值 (19KB) ， 然 后 从 这 点 开始 又 采用 “拥塞 避免 "方案 发 
送 数据 ， 依 此 类 推 。 


CWND(KB) 


Ne ne 

第 二 次 调整 的 阔 值 
第 二 次 “ 慢 
启动 ”过 程 


传输 序号 


1 2 3 4 5 6 了 8 9 10 11 12 13 14 15 16 17 


图 10-49 “ 慢 启动 * 和 “拥塞 避免 "方案 数据 发 送 示例 


3. 快 速 重 传 /快速 恢复 


上 面 介 绍 的 “ 慢 启 动 * 和 “拥塞 避免 ”是 1988 年 提出 的 拥塞 控制 方案 ， 
而 1990 年 又 新 增 了 两 种 拥塞 控制 方案 ， 束 是 下 面 要 介绍 的 “快速 重 
传 " 和 “快速 恢复 ”拥塞 控 制 方案 。 


“快速 重 传 ” 方 案 的 基本 思想 ， 当 接收 端 收 到 一 个 不 是 按 序 到 达 的 
数据 段 时 ，TCP 实 体 迅速 发 送 一 个 重复 ACK 数 据 段 ， 而 不 用 等 到 有 效 
据 需 要 发 送 时 顺带 发 出 确认 ; 在 重复 收 到 三 个 重复 ACK 数 据 段 后 ， 即 
认为 对 应 “确认 号 ?字段 的 数据 段 已 经 丢失 ，TCP 不 等 重 传 定 时 器 超时 就 
重 传 看 来 已 经 丢失 的 数据 段 。 


为 了 进一步 理解 “快速 重 传 * 原 理 ， 现 举 一 个 如 图 10-50 所 示 的 示 
例 。 假 设 每 次 只 发 送 一 个 大 小 等 于 MSS 的 数据 段 ， 并 假设 在 第 一 次 、 


第 二 次 发 送 M1、M2 后 ， 发 送 并 部 从 接收 端 收 到 了 确认 ， 但 第 三 次 发 送 
的 M3 在 途中 丢失 了 ， 而 后 面 第 四 次 发 送 的 M4 又 收 到 了 。 正 常情 况 ， 接 
收 闹 是 不 会 再 发 送 任 何 确认 数据 段 的 ， 直 到 收 到 M3 为 止 。 然 而 ， 发 送 
端 此 时 并 不 知道 M3 丢失 了 ， 继 续 发 运 M4， 在 接收 端 收 到 M4 时 ， 为 了 
尽快 通知 发 送 端 M3 还 没有 收 到 ， 于 是 再 次 发 送 一 个 M2 确认 数据 段 (其 
中 的 “确认 号 ”字段 值 是 M3 的 序号 ) ， 相 当 于 再 次 提醒 发 送 端 M3 数 据 段 
没收 到 。 但 此 时 发 送 端 还 不 会 重 发 M3， 布 望 再 等 等 看 ， 仍 然 继续 依次 
发 送 M5、M6， 在 接收 器 每 收 到 一 个 数据 段 后 均 会 有 一 个 重复 的 M2 确 
认 。 在 发 送 端 收 到 了 四 个 针对 M2 数据 段 的 确认 (一 个 确认 M2， 三 个 重 
复 确认 M2) 时 ， 发 送 端 就 会 立即 发 送 M3， 尽 管 此 时 可 能 M3 的 重 传 定 


时 器 还 没 过 期 。 


发 送 端 接收 端 


人 AM 确认 M1 
发 送 M2 = 

确认 M2 
发 送 M3 
发 送 M4 

es 重复 确认 M2 

发 送 M5 

重复 确认 M2 
发 送 M6 

重复 确认 M2 
重 发 M3 


图 10-50 “快速 重 传 ”方案 数据 重 传 示例 


在 “快速 重 传 "算法 发 送 了 看 似 已 经 丢失 的 数据 段 后 ,，“ 快 速 恢 复 ” 算 
法 同时 开始 发 挥 作用 。“ 快 速 恢 复 ” 算 法 的 基本 思想 ， 在 收 到 第 三 个 重 
复 ACK 时 ， 把 当前 CWND 值 设 为 当前 SSTHRESH 值 的 一 半 ， 以 减轻 网 


络 负 和 谷 ， 然 后 执行 前 面 介绍 的 “ 拥 压 避免 "算法 ， 


pa 


以 避免 再 次 出 现 网 络 拥 塞 。 


使 CWND 值 慢 慢 增 


10.7 UDP 概述 


在 网 络 体系 结构 的 “传输 层 * 中 ， 主 要 的 传输 层 协 议 就 古 前 面 介绍 
的 TCP， 它 是 可 靠 的 传输 层 协议 ， 可 以 提供 可 徘 的 数据 传输 。 然 而 ， 
还 有 一 些 网 络 应 用 ， 应 用 的 连续 性 和 可 靠 性 可 能 更 重要 ， 如 视频 会 
议 、 语 首 电 话 ， 其 中 丢失 一 部 分 数据 的 影响 并 不 大 ， 用 户 通 过 上 、 下 
部 分 的 内 容 可 能 猜 得 出 来 ， 甚 至 这 部 分 影响 很 难看 得 出 来 ， 但 如 采 出 
现 传输 中 断 ， 或 者 延迟 严重 ， 可 能 融 无 法 接受 了 。 于 是 ， 出 现 了 一 种 
不 面向 连接 的 传输 层 一 一 UDP (User Datagram Protocol， 用 户 数据 报 
文 协议 ) 。 


10.7.1 UDP 的 基础 知识 


UDP 起 一 种 无 连接 传输 层 协 议 ， 不 像 TCP 那 样 需要 服务 右 监 听 ， 
也 不 必 等 得 客户 闻 与 服务 器 建立 连接 后 才能 通信 ， 当 然 ， 最 后 能 否 把 
数据 传输 成 功 ，UDP 是 不 能 保证 的 。 


妆 
缉 


前 面 介 绍 的 TCP 采 用 的 是 面 癌 连接 的 分 组 报 文 传输 方式 ， 而 UDP 
采用 的 是 无 连接 的 数据 报 传输 方式 。 分 组 报 文 头 部 是 有 明确 的 源 地 址 
和 目的 地 址 的 ， 而 数据 报头 部 是 没有 这 些 信息 的 。 该 服务 对 请 轧 中 传 
输 的 数据 提供 不 可 徘 的 、 尽 最 大 努力 的 传送 。 这 意味 看 它 不 保证 数据 


报 的 到 达 ， 也 不 保证 所 传送 数据 包 的 顺序 是 否 正确 。 总 体 来 说 ，UDP 
具有 以 下 几 个 方面 的 明显 特性 : 


(1) 无 连接 性 


UDP 可 以 提供 无 连接 的 数据 报 服务 ， 这 也 决定 了 在 使 用 UDP 进行 
数据 传输 前 是 不 需要 建立 专门 的 传输 连接 的 ， 当 然 ， 在 数据 发 送 结束 
时 也 无 须 释 放 连 授 了 。 


(2) 不 可 靠 性 


因为 UDP 传输 数据 时 征 不 需要 事先 建立 专门 的 传输 连接 的 ， 所 以 
它 的 传输 是 不 可 靠 的 〈 但 会 尽 最 大 努力 进行 交付 ) ， 很 可 能 传输 不 成 
功 。UDP 特 别 适 用 于 一 些 短 消 轧 类 的 数据 传输 ， 如 DHCP、DNS 中 的 
一 些 消息 吏 是 采用 UDP 进行 传输 的 。 


(3) 以 报 文 为 边界 


UDP 直接 对 应 用 层 提 区 的 报 文 进行 封装 、 传 输 ， 但 不 拆 分 ， 也 不 
合并 ， 保 留 原来 报 文 的 边界 。 因 此 ，UDP 是 报 文 流 ， 而 TCP 是 字 市 
流 。 因 为 UDP 不 拆 分 报 文 ， 目 然 也 束 没 有 报 文 段 之 说 ， 但 UDP 报 文 传 
输 到 网 络 层 后 ， 在 网 络 层 仍然 可 以 根据 网 络 的 MTU 值 进行 分 割 。 


(4) 无 流量 控制 和 拥塞 控制 功能 


使 用 UDP 进 行 数据 传输 时 不 能 进行 流量 控制 和 拥塞 控制 ， 因 为 这 
类 数据 传输 的 连续 性 要 比 数据 的 完整 性 更 重要 ， 人 允许 数据 在 传输 过 程 
中 有 部 分 丢失 ， 如 IP 电 话 、 流 媒体 通信 等 。 


(5) 文 持 各 种 交互 通信 方式 


TCP 不 文 持 组 播 、 广 播 通信 方式 ， 只 文 持 一 对 一 的 单 播 方式 ， 但 
UDP 文 持 各 种 通信 方式 ， 即 可 以 是 一 对 一 、 一 对 多 、 多 对 一 和 多 对 多 
的 为 2。 


计算 机 网 络 中 有 许多 使 用 UDP 的 应 用 服务 ， 如 DNS、SNMP、 
DHCP 和 RIP 等 。 


10.7.2 ”UDP 数据 报头 部 格式 


UDP 数据 报 格式 比较 简单 ， 如 图 10-51 所 示 ， 其 中 “数据 ”字段 是 来 
目 应 用 层 的 报 文 内 容 ， 其 他 部 分 为 UDP 协议 头 ， 总 共 8 字 世 。 下 面 是 
UDP 效 据 报头 部 各 字段 的 说 明 : 


图 10-51 UDP 数据 报 格式 


(1) 源 端 口 
源 剖 口子 段 用 来 标识 源 主机 上 使 用 的 UDP 问 口 ， 占 16 位 (2 子 
广 ) 。 这 个 字段 是 可 选 的 ， 仪 当 和 需要 目的 主机 返回 一 个 应 管 时 才 有 意 
义 。 如 采 不 使 用 它 ， 则 此 字段 值 为 0。 


(2) 目的 端口 


i 


目的 端口 字段 用 来 标识 目的 主机 上 使 用 的 UDP 冰 口 ， 占 16 位 (2 字 
订 ) 。 如 果 目 的 主机 应 用 层 没 有 对 应 端口 的 应 用 进程 ， 则 该 UDP 数据 
报 会 做 去 译 * 


(3) 长 度 


长 度 字段 用 来 标识 此 UDP 数据 报 的 长 度 (包括 UDP 数 据 报头 部 
和 “数据 ”部 分 ， 以 字 节 为 单位 ， 占 16 位 (2 字 节 ) 。 因 为 一 个 IP 分 组 
的 最 大 长 度 为 65535 字 节 ， 所 以 ， 理 论 上 的 UDP 数据 报 “ 数 据 ?” 部 分 的 最 
大 长 度 为 65535-20 〈 最 小 IP 报 头 ) -8 (UDP) =65507 字 节 。 但 实际 上 在 
互联 网 中 通常 是 限制 在 512 字 节 以 内 ， 这 主要 是 受 互 联网 结构 比较 复 
杂 、 接 入 性 能 比较 低 影响 的 。 


(4) 校 验 和 


在 进行 校 验 和 计算 时 ， 需 要 在 UDP 数据 报头 部 前 加 上 12 字 节 的 伪 
头 部 〈 如 图 10-52 所 示 ， 它 不 是 数据 中 的 真实 成 分 ， 也 不 用 来 传输 ， 仅 
用 来 计算 校 验 和 ) ， 然 后 对 整个 UDP 头 部 和 “数据 ”部 分 进行 校 验 。 通 
党 是 采用 CRC 校 验方 式 ， 具 体 参 见 7.3.4 广 相关 内 容 。 


2 3 8 8 16 
a| 2 


图 10-52 UDP 伪 头 部 


因为 UDP 无 连接 管理 ， 无 差错 控制 ， 也 无 拥塞 控制 ， 所 以 比较 简 
FE 


第 11 章 ”应 用 层 


在 OSUVRM 体 系 结构 的 “传输 层 " 之 上 、“ 应 用 层 ” 之 下 有 ”会话 
层 ” 和 “表示 层 "”， 但 实际 上 这 两 层 的 功能 都 非常 简单 ， 因 此 ， 在 TCP/IPP 
体系 结构 中 ， 这 两 层 的 功能 整合 到 “应 用 层 ” 中 ， 现 在 的 各 种 网 络 应 用 
程序 也 是 按照 这 种 结构 来 进行 程序 设计 的 。 本 书 不 再 单独 介绍 “会 话 
层 ” 和 “表示 层 ”， 而 是 直接 介绍 体系 结构 的 最 高 层 一 一 应 用 层 。 


前 面 各 章节 介绍 的 内 容 主 要 完成 两 方面 的 功能 ， 一 是 网 络 连接 的 
建立 (或 者 说 是 网 络 通信 平台 的 搭建 ) ， 二 是 数据 传输 通道 (包括 数 
据 链 路 层 构建 的 局 域 网 内 部 点 对 点 数据 传输 通道 和 传输 层 构 建 的 不 同 
网 络 间 端 对 端 数据 传输 通道 ) 的 建立 。 它 们 的 最 终 目 的 只 有 一 个 ， 那 
就 是 为 运行 的 网 络 应 用 搭建 有 效 的 平台 ， 这 就 是 本 章 将 要 介绍 的 内 
容 ， 即 OSVRM 和 TCP/IP 体 系 结构 的 最 高 层 一 一 “应 用 层 ” 所 提供 的 应 用 
服务 。 但 要 注意 的 是 ， 应 用 层 提 供 的 同样 是 服务 ， 而 不 是 提供 具体 的 
网 络 应 用 软件 。 但 与 其 他 各 层 一 样 ， 在 网 络 体系 结构 中 ， 每 一 层 都 有 
一 个 服务 作用 实体 ,“ 应 用 层 ” 的 实体 (AE) 就 是 各 种 正在 运行 的 用 户 
网 络 应 用 进程 。 


随 看 网 络 技术 的 发 展 和 网 络 应 用 的 普及 ， 各 方面 的 网 络 应 用 也 不 
断 请 现 。 每 类 网 络 应 用 都 需要 对 应 的 应 用 服务 文 择 , “应 用 层 ” 要 解决 
的 问题 惑 是 为 用 户 提供 所 需 的 应 用 服务 。 这 些 网 络 应 用 服务 都 挟 C/S 


(客户 端 /服务 器 ) 工作 模式 ， 当 然 ， 有 的 是 客户 端 与 服务 器 分 离 (也 
就 是 一 台 主 机 要 么 担当 客户 端 角 色 ， 要 么 担当 服务 器 角色 ， 不 能 同时 
安装 两 种 角色 的 服务 软件 ) ， 有 的 是 两 者 同时 支持 。 本 章 主要 介绍 
HTTP 《Web 服 务 ) 、E-mail (电子 邮件 服务 ) 、DNS (域名 解析 服 
) 、DHCP 《动态 主机 配置 服务 ) 四 类 网 络 应 用 服务 的 客户 端 和 服 
器 的 基本 工作 原理 。 


务 
务 


11.1 应 用 层 概述 


应 用 层 是 OSIRM 和 TCP/P 体 系 结构 的 最 高 层 ， 通 过 使 用 下 面 各 层 
所 提供 的 服务 ， 直 接 向 用 户 提 供 服务 ， 是 计算 机 网 络 与 用 户 之 间 的 办 
面 或 接口 。 就 像 其 他 各 层 所 提供 的 服务 一 样 ， 应 用 层 的 各 种 服务 功能 
也 是 通过 具体 的 通信 协议 来 实现 的 。 


应 用 层 的 网 络 应 用 服务 非常 多 ， 而 且 有 许多 是 用 户 每 天 在 使 用 
的 ， 如 Web 服 务 、 电 子 邮 件 服务 、 DNS (域名 服务 ) 、DHCP (IP 地 址 
自动 分 配 服务 ) 、 文 件 传输 服务 、 远 程 登录 服务 等 。 随 着 互联 网 应 用 
的 普及 和 发 展 ， 各 种 新 的 网 络 应 用 服务 层出不穷 ， 本 章 仅 介绍 在 
TCP/IP 网 络 中 最 常用 的 一 些 服 务 。 


11.1.1 应 用 层 组 件 及 典型 应 用 服务 


为 了 向 用 户 提供 有 效 的 网 络 应 用 服务 ， 应 用 层 需 要 确立 相互 通信 
的 应 用 程序 或 进程 的 有 效 性 并 提供 同步 ， 需 要 提供 应 用 程序 或 进程 所 
需要 的 信息 交换 和 远程 操作 ， 需 要 建立 错误 恢复 的 机 制 以 保证 应 用 层 
数据 的 一 致 性 。 应 用 层 为 各 种 实际 网 络 应 用 所 提供 的 通信 支持 服务 统 
称 为 ASE (Application Service Element， 应 用 服务 组 件 ) 。 


不 同 的 ASE 可 以 方便 地 让 各 种 实际 的 网 络 应 用 与 下 层 进行 通信 。 
其 中 ， 最 重要 的 3 个 ASE 分 别 是 ACSE (Association Control Service 
Element， 关 联 控制 服务 组 件 ) 、ROSE (Remote Operation Service 
Element， 远 程 操作 服务 组 件 ) 和 RTSE (Reliable Transfer Service 
Element， 可 靠 传输 服务 组 件 ) 。ACSE 可 以 将 通信 两 端 用 户 所 使 用 的 
应 用 程序 名 关联 起 来 ， 用 于 在 两 端 应 用 程序 之 间 建 立 、 维 护 和 终止 连 
接 ; ROSE 采 用 类 似 远程 过 程 调用 的 请 求 /应 答 机 制 实 现 远程 操作 :; 
RISE 则 通过 先 将 数据 转化 为 8 位 字 节 串 ， 然 后 将 数据 串 分 解 为 多 个 
段 ， 最 后 将 每 段 传 送 到 表示 层 ， 以 便 发 送 在 分 段 之 间 建 立 检 验 点 。 通 
过 表示 层 服 务 ，RTSE 使 用 会 话 层 活动 管理 服务 来 管理 数据 分 段 的 传 


输 。 


除了 以 上 提 到 的 3 个 应 用 服务 组 件 外 ，OSIRM 体 系 结构 的 应 用 层 

提供 了 5 种 不 同 的 网 络 应 用 类 型 来 实现 不 同 的 应 用 需求 ， 分 别 是 MHS 

(Message Handling System， 报 文 处 理 系统 ) 、FTAM (File Transfer， 
Access and Management， 文 件 传输 、 存 取 和 管理 ) 、VTP (Virtual 


Terminal Protocol， 虚 拟 终端 协议 ) 、DS (Directory Service， 目 录 服 
务 ) 、TP (Transaction Processing， 事 物 处 理 ) 、RDA (Remote 
Database Access， 远 程 数据 库 访 问 ) 。 但 由 于 目前 OSVRM 体 系 结构 只 
是 起 到 参考 模型 的 作用 ， 所 以 并 没有 实际 的 网 络 应 用 是 按照 上 述 协 议 
实现 的 。 而 在 TCP/IP 体 系 结构 中 的 应 用 层 却 相反 ， 拥 有 许多 主流 的 应 
用 层 协议 和 基于 这 些 协 议 实 现 的 TCP/IP 应 用 。 


TCP/IP 体 系 结构 中 的 应 用 层 解 决 了 TCP/IP 网 络 应 用 存在 的 共性 问 
题 ， 包 括 与 网 络 应 用 相关 的 支撑 协议 和 应 用 服务 两 大 部 分 。 其 中 的 支 
撑 协 议 包括 域名 服务 系统 (DNS) 、 动 态 主 机 配置 协议 (DHCP) 、 
简单 网 络 管理 协议 (SNMP) 等 ; 典型 的 应 用 服务 包括 Web 浏 览 服务 、 
E-mail 服 务 、 文 件 传输 访问 服务 、 远 程 登录 服务 等 ， 另 外 ， 还 有 一 些 
与 这 些 典 型 网 络 应 用 服务 相关 的 协议 ， 包 括 超 文本 传输 协议 

(HTTP) 、 简 单 邮件 传输 协议 (SMTP) 、 文 件 传输 协议 (FTP) 、 
简单 文件 传输 协议 (TFTP) 和 远程 登录 (Telnet) 等 。 


11.1.2 ”应 用 层 的 C/S 服 务 模型 


网 络 应 用 软件 之 间 最 常用 、 最 重要 的 交互 模型 是 C/S 
(Client/Server， 客 户 端 /服务 器) 模型 。 例 如 ，Web 服 务 、E-mail 服 
务 、DNS 服 务 、DHCP 服 务 、FTP 服 务 等 都 是 以 这 种 模型 为 基础 工作 
的 。 这 里 所 说 的 “客户 端 " 和 “服务 器 * 分 别 是 指 通信 双方 主机 上 安装 的 对 
应 应 用 程序 。 


网 络 上 的 应 用 程序 之 间 为 了 能 够 顺利 通信 ， 一 方 通常 需要 处 于 守 
候 状 态 ， 等 待 另 一 方 请 求 的 到 来 。 这 就 是 本 市 所 介绍 的 C/S 模 型 ， 首 先 
服务 器 需要 时 刻 守候 各 种 应 用 服务 (通常 是 通过 监听 各 个 传输 端口 来 
实现 ) ， 然 后 客户 端 向 服务 器 发 出 对 应 的 应 用 会 话 请 求 ， 最 后 服务 器 
对 客户 端的 会 话 请 求 做 出 响应 。 如 图 11-1 所 示 的 是 TCP/ 耻 体系 结构 中 一 
个 通过 Internet 进 行 交 互 的 C/S 模 型 示例 。 在 图 11-1 中 ， 服 务 右 处 于 守候 
状态 ， 并 监听 客户 端的 会 话 请 求 ， 在 客户 端 发 出 应 用 会 话 请 求 命令 ， 
并 经 Internet 传 输 给 服务 器 后 ， 服 务 器 接收 到 这 个 会 话 请 求 ， 并 执行 相 
YY 会 话 请 求 所 指定 的 任务 ， 最 后 将 执行 的 结果 以 应 答 消 息 经 Internet 返 


回 给 客户 端 。 


Pra 3 XU [ela] 
各 户 期 服务 器 


立 用 进程 
和 


传输 层 


Internet 


图 11-1 应 用 服务 的 C/S 模 型 示例 


一 台 主 机 上 通常 可 以 运行 多 个 应 用 服务 器 程序 ， 每 个 服务 器 程序 
需要 并 发 地 处 理 多 个 客户 的 请 求 ， 并 将 处 理 的 结果 返回 给 客户 端 。 因 
此 ， 服 务 器 程序 通常 比较 复杂 ， 对 主机 的 硬件 资源 〈 如 CPU 的 处 理 速 
度 、 内 存 的 大 小 等 ， 及 软件 资源 (如 分 时 、 多 线程 网 络 操 作 系 统 等 ) 
都 有 一 定 的 要 求 。 而 客户 端 程序 功能 则 相对 简单 ， 通 音 不 需要 特殊 的 
硬件 和 高 级 的 网 络 操作 系统 。 


C/S 模 型 不 但 很 好 地 解决 了 互联 网 应 用 程序 之 间 的 同步 问题 〈 何 时 
开始 通信 、 何 时 发 送信 息 、 何 时 接收 信息 等 ) ， 而 且 C/S 模 型 的 这 种 非 


对 等 相互 作用 的 特点 很 好 地 适应 了 互联 网 资源 分 配 不 均 的 客观 事实 ， 
因此 成 为 互联 网 应 用 程序 相互 作用 的 主要 模型 。 


在 TCP/IP 互 连 网 络 中 ， 服 务 器 程序 通常 使 用 TCP 或 UDP 的 端口 号 作 
为 自己 的 特定 标志 。 在 服务 器 程序 启动 时 ， 首 先 在 本 地 主机 注册 自己 
使 用 的 TCP 或 UDP 端 口号 ， 这 样 服务 右 程 序 在 声明 该 端口 号 已 被 占用 的 
同时 ， 也 通知 本 地 主机 如 果 在 该 端口 上 收 到 信息 ， 则 需要 将 这 些 信息 
转交 给 注册 该 端口 的 服务 器 程序 处 理 。 在 客户 端 程序 需要 访问 某 个 服 
务 时 ， 可 以 通过 与 服务 器 程序 使 用 的 TCP 端 口 建立 连接 〈 或 直接 向 服务 
器 程序 使 用 的 UDP 端口 发 送信 息 ) 来 实现 。 


在 互连网 络 中 ， 客 户 发 起 请 求 完全 是 随机 的 ， 有 可 能 出 现 多 个 请 
求 同 时 到 达 服 务 句 的 情况 。 因 此 ， 服 务 紫 必须 具备 处 理 多 个 并 发 请 求 
的 能 力 ， 可 以 使 用 以 下 两 种 方案 。 


(1) 迭代 服务 器 (iterative server) 方案 


在 适 代 服务 器 解决 方案 中 ， 服 务 器 程序 中 包含 一 个 请 求 队列 ， 客 
户 请 求 到 达 后 首先 进入 队列 中 等 待 ， 服 务 器 按照 先进 先 出 的 原则 对 这 
些 客户 端 请 求 一 个 个 做 出 响应 ， 即 服务 器 只 有 处 理 完 前 一 个 请 求 后 才 
会 处 理 下 一 个 请 求 。 


(2) 并 发 服务 器 (concurrent server) 方案 


并 发 服务 器 是 一 个 守护 进程 ， 在 没有 请 求 到 达 时 它 处 于 等 待 状 
态 。 一 旦 客户 端 请 求 到 达 ， 服 务 器 立即 再 为 之 创建 一 个 子 进程 ， 然 后 
回 到 等 待 状态 ， 由 了 于 进程 啊 应 请 求 。 当 下 一 个 于 进程 到 达 时 ， 服 务 器 
再 为 之 创建 一 个 子 进 程 。 其 中 ， 并 发 服务 器 称 做 主 服 务 嚣 ， 子 进程 称 
做 从 服务 器 。 


11.2 ” ”Web 服务 基础 


目前 网 络 应 用 中 普及 度 最 高 、 应 用 频次 最 多 的 是 通常 所 说 的 万 维 
网 (World Wide Web，WWW) 服务 ， 或 者 称 为 Web 服 务 。Web 服 务 的 
核心 应 用 层 协议 是 HTTP (Hypertext Transfer Protocol， 超 文本 传输 协 
议 ) ， 也 可 以 把 HTTP 看 成 是 Web 服 务 的 “幕后 英雄 ”。 


进行 网 站 访问 时 好 像 觉 得 非常 们 单 ， 点 一 下 鼠标 ， 或 者 输入 一 个 
网 站 名 称 束 进 去 了 ， 其 实 它 仍 需要 一 整套 Web 服 务 功能 来 实现 ， 其 中 涉 
及 许多 协议 和 网 络 应 用 程序 功能 。 下 面 先 来 分 析 一 下 Web 服 务 模型 (或 
者 称 为 Web 服 务 系统 结构 ) 。 


11.2.1 ”Web 服务 模型 


任何 网 络 应 用 服务 都 不 是 单一 程序 或 者 单一 命令 可 以 实现 的 ， 它 
们 必须 有 一 个 能 实现 服务 请 求 、 服 务 提供 ， 甚 至 包括 服务 注册 的 完整 


系统 结构 ， 束 宇通 闻 所 说 的 “服务 模型 ”。 


从 用 户 的 角度 来 看 ，Web 服 务 ， 或 者 所 有 互联 网 网 站 其 实 束 是 一 个 
全 球 范 围 内 的 巨大 文档 ， 更 具体 地 说 加 是 Web 页 面 集 合 。 有 了 上 述 基本 
认识 ， 可 以 很 容易 得 出 Web 服 务 模型 ， 如 图 11-2 所 示 。Web 服 务 模型 包 
括 3 个 部 分 ，Web 服 务 提 供 者 “Web 服务 器 ) 、Web 服 务 请 求 者 (Web 客 


尸 端 ) 和 Web 服 务 注册 中 心 《互联 网 注册 、 管 理 机 构 ) ， 其 中 “Web 服 
务 注册 中 心 ”是 可 选项 ， 仪 在 互联 网 中 的 Web 服 务 才 是 需要 注册 的 ， 而 
局 域 网 中 是 不 需要 的 。 


Web 服 务 注册 中 心 


查询 请 求 注册 、 解 析 请 求 


解析 啊 应 


查询 啊 应 


请 求 服 务 


Web 服 务 请 求 者 服务 提供 


Web 服 务 提供 者 


图 11-2 ” Web 服务 模型 


下 面 简单 介绍 Web 服 务 模型 中 3 个 组 成 部 分 的 基本 功能 


口 Web 服 务 注册 中 心 : 指 互 联网 注册 、 管 理 中 心 和 提供 网 站 域名 解 
析 的 ISP 《Iternet 服 务 提 供 商 ) ， 是 一 个 可 选 部 分 ， 而 在 仅 用 于 局 域 网 
内 部 的 网 站 访问 中 无 须 使 用 此 部 分 。 它 负责 互联 网 网 站 的 注册 和 管 


理 ， 并 向 用 户 提供 互联 网 域名 解析 服务 。 因 为 它 主要 涉及 域名 解析 服 
务 “_DNS， 所 以 在 本 章 后 面 介绍 DNS 服务 时 再 进行 详细 介绍 。 


口 Web 服 务 提供 者 ， 指 Web 服 务 器 ， 或 者 称 做 Web 网 站 ， 是 HTTP 服 
务 器 端 。 它 是 由 一 些 Web 服 务 器 程序 (如 IIS、Apache 等 ) 开发 的 ， 除 
了 要 对 网 站 本 身 进行 描述 ， 并 向 注册 中 心 注册 外 ， 更 重要 的 职责 是 大 
Web 访 问 用 户 提 供 所 需 的 网 页 信息 。 


口 Web 服 务 请 求 着， 指 Web 用 户 在 访问 网 站 时 所 用 的 HTTP 客 户 绵 
程序 ， 如 各 种 浏览 器 (如 IE、Chrome 浏 览 器 等 。 在 Web 浏 览 器 中 输 
入 网 站 的 域名 或 PP 地址， 或 者 在 其 他 网 站 或 文档 上 单 击 该 网 站 的 链接 
即 可 进入 到 对 应 的 网 站 ， 然 后 再 单 击 相应 的 页 面 链接 访问 所 需要 的 文 
字 、 图 片 、 音 /视频 等 页 面 。 


以 上 各 组 成 部 分 均 包括 一 些 协议 ， 并 由 支持 这 些 协议 的 网 络 应 用 
软件 来 实现 。 本 市 仅 介 绍 “Web 服 务 提供 者 "和 “Web 服 务 请 求 者 ”这 两 部 
分 的 功能 实现 原理 。 下 面 匈 了 解 一 下 万 维 网 的 一 些 基 本 特性 。 


11.2.2 “万维网 的 全 球 统一 标识 


如 采 没 有 一 个 基于 全 球 苍 围 的 唯一 标识 ， 那 么 要 在 互联 网 中 找到 
你 需要 访问 的 那 一 个 网 站 或 网 页 ， 有 是 无 法 想象 的 。 在 万 维 网 中 ， 存 在 3 


种 全 球 统 一 标识 ， 分 别 是 URL (Uniform Resoure Locator， 统 一 资源 定 


位 器 ) 、URI (Uniform Resource Identifier， 统 一 资源 标识 符 ) 和 URN 


(Uniform Resource Name， 统 一 资源 名 称 ) 


这 3 种 标识 不 仅 看 起 来 非常 相似 ， 而 且 关 系 也 非常 密切 。 从 它们 的 
中 文 名 称 可 以 看 出 ，URL 是 用 来 定位 资源 的 ， 标 识 的 是 访问 对 应 资源 
的 路 径 ， 而 URI 是 用 来 标识 资源 的 ，URN 则 是 用 来 为 资源 命名 的 。 注 
意 ，URI 中 的 标识 符 可 以 是 资源 的 名 称 ， 也 可 以 是 资源 的 地 址 。 另 
外 ，URI 在 RFC1630 中 定义 ， 发 布 于 1994 年 6 月 ，URL 在 RFC1738 中 定 
义 ， 发 布 于 1994 年 12 月 ，URN 在 RFC1737 中 定义 ， 发 布 于 1994 年 12 
月 。 从 中 也 可 以 看 出 ， 是 先 有 URI， 然 后 才 有 URL 和 URN，URL 和 
URN 是 URI 扩 展 后 的 子 集 。 下 面 对 它们 分 别 进行 介绍 


1.URL 


互联 网 上 的 网 站 ， 无 论 它 的 服务 器 位 于 哪里 ， 用 户 在 连接 上 互联 
网 的 计算 机 的 浏览 器 中 输入 这 个 网 站 的 网 址 都 可 以 轻易 访问 到 该 网 
站 ， 或 者 该 网 站 上 的 对 应 页 面 。 这 束 征 Web 网 站 上 所 有 资源 的 统一 定 


位 标识 特性 一 一 URL， 它 是 URI 的 一 种 。URL 标 识 一 个 互联 网 资源 ， 
并 指定 对 其 进行 操作 或 取得 该 资源 的 方法 。 这 里 所 说 的 “资源 ”是 指 在 
互联 网 上 可 以 访问 的 任何 对 象 ， 包 括 文件 目录 、 文 件 、 文 档 、 图 片 、 
图 像 、 音 /视频 ， 甚 至 是 电子 邮件 地 址 等 。 


URL 和 采用 了 全 球 统一 的 格式 来 标识 万 维 网 上 资源 的 访问 地 址 ， 以 
确保 每 个 互联 网 网 站 和 网 站 页 面 在 全 球 范 围 内 都 有 唯一 的 地 址 标识 。 
URL 的 一 般 格式 (其 实 后 面 还 可 以 有 可 选项 ) 为 : 


< 协议 > ://< 主 机 名 > : < 端口 > /< 路 径 > 


(1) 协议 


这 里 的 “协议 ”参数 是 指 访问 对 象 所 使 用 的 协议 ， 包 括 HTTP 、 
FTIP、Gopher、Telnet、File、Mailto 等 。 注 意 ， 在 协议 后 须 加 上 “://”。 


(2) 主机 名 
“主机 和 ?参数 是 指 Web 服 务 右 名 称 ， 互 联网 上 的 服务 右 主 机 名 束 
征 网 站 的 域名 ， 用 来 指定 用 户 要 访问 的 是 哪 台 服务 套 主 机 。 互 联网 的 


主机 名 通常 是 以 www 开 始 的 (但 不 全 是 ) ， 后 面 必须 跟着 “:”( 冒 
号 ) ， 以 指定 访问 对 象 建立 通信 连接 时 所 用 的 传输 层 端口 。 


“ 冰 口 ”参数 用 来 指定 在 建立 连接 时 所 用 的 传输 层 端 口号 。 如 采 采 
用 的 是 种 规 协议 ， 端 口号 可 以 省 略 ， 直 接 使 用 默认 的 端口 号 ， 如 HTTP 
的 殉 认 靖 口 号 为 0，FTP 的 默认 靖 口 号 为 21，Telnet 的 默认 疹 口 喜 为 
23。 即 使 是 常规 协 议 ， 所 使 用 的 端口 号 也 可 以 更 改 ， 但 一 定 要 与 Web 
服务 硕 上 设置 的 端口 一 致 ， 否 则 访问 不 了 。 端 口号 后 面 跟 的 “7 代表 服 
务 器 的 根 目 好。 


(4) 路 径 


“路 径 ?参数 用 来 指定 要 访问 的 对 象 在 Web 服 务 伙 上 的 文件 路 径 ， 
与 本 地 主机 上 的 文件 路 径 格式 一 样 ， 以 根 目录 〈《/) 开始 。 如 果 要 访问 
的 是 网 站 首页 ， 则 不 用 输入 此 部 分 ， 直 接 以 前 面 的 “符号 访问 服务 紫 
的 根 目 录 即 可 。 


如 有 果 要 访问 51CTO 网 站 ， 则 可 以 在 浏 宽 右 地 址 栏 中 输入 : 
http://www.51cto.com， 当 然 ， 现 在 的 浏览 器 可 以 不 用 输 
入 “http:#/P 和 “/” 这 两 部 分 了 ， 浏 蜗 絮 会 目 动 为 用 户 加 上 的 ， 男 外 ， 没 有 
指定 端口 时 ， 直 接 使 用 HTTP 的 默认 端口 号 80。 


如 果 要 直接 访问 在 51CTO 博 客 中 的 一 篇 文 草 ， 那 么 可 以 在 浏览 絮 
地 址 栏 中 输入 如 下 地 址 : http://winda.blog.51cto.com/55153/868663， 其 
中 , “winda.blog.51cto.com” 是 在 51CTO 博 客 上 的 博客 域名 ， 后 面 
的 “/55153/868663” 是 这 篇 文章 的 路 径 。 


如 果 要 访问 一 个 域名 为 ftp.winclass.net 的 FTP 站 点 ， 则 可 表示 为 
ftp:/ftp.winclass.net， 当 然 ， 这 里 是 没有 考虑 访问 用 户 账 户 的 ， 如 果 要 
访问 一 个 电子 邮箱 winda@wincalss.net， 则 可 输入 : 


mailto:winda(Dwincalss.net。 
2.URI 和 URN 


上 文 提起 到 过 ，URL 和 URN 都 是 URI 的 子 集 ， 在 应 用 上 可 视 为 
URL、URN 或 两 者 兼备 。URL 上 文 介绍 过 ， 而 URN 仅 是 指 资源 的 名 
称 ， 如 国际 书号 、 互 联网 电子 邮箱 账户 、RFC 文 档 等 。URN 如 同一 个 
人 的 名 称 ， 而 URL 代 表 一 个 人 的 住址 ， 但 这 两 种 统一 标识 实际 上 使 用 
频率 并 不 高 ， 现 在 主要 用 的 还 是 URL 。 


URI 的 基本 语法 格式 如 下 : 


< 方案 名 > : < 主机 名 > /< 路 径 > 


其 中 ,“ 方 案 名 ”是 指 对 资源 进行 标识 的 协议 (但 有 时 不 是 直接 用 
协议 名 本 号 显示 ) 。 后 面 的 “主机 名 ”是 指 保存 资源 的 服务 器 域名 ， 
而 “路 径 ” 是 资源 的 保存 路 径 ， 它 不 会 随访 问 路 径 变 化 而 变化 。 下 面 是 
几 种 常见 URI 类 型 的 基本 格式 。 


Dmailto:mbox@domain: 指定 通过 SMTP 发 送 电子 邮件 的 电子 邮 
箱 地 址 。 


口 ftp://user:pass(@server/file: 指定 通过 FTP 传 输 文 件 的 用 户 账户 和 
文件 位 置 。 


口 http://domain/path: 指定 通过 HTTP 访 问 的 网 站 或 网 页 的 路 径 。 
Dfile:/path: 标识 在 本 地 磁盘 或 者 网 络 文件 系统 上 的 文件 地 址 。 


其 中 ， 第 一 种 类 型 既 可 以 说 是 一 个 URN， 也 可 以 说 是 一 个 URL， 
本 例 中 标识 的 是 一 个 电子 邮箱 名 称 ， 而 其 他 3 个 是 URL 。 


11.2.3 ”万维网 文档 标记 


因为 web 用户 使 用 的 操作 系统 、 浏 览 器 类 型 多 种 多 样 ， 这 些 操 作 系 
统 和 浏览 器 所 使 用 的 开发 语言 也 可 能 完全 不 同 ， 所 以 为 了 在 不 同 用 户 
计算 机 上 都 能 正确 地 显示 万 维 网 中 的 网 页 信息 ， 也 必须 为 网 站 的 信息 
制定 全 球 统一 的 表示 方法 〈 称 为 “标记 ”方法 ) ， 那 就 是 本 节 要 重点 介 
绍 的 HTMIL (HyperText Markup Language， 超 文本 标记 语言 ) 。 


HTML 是 一 种 万 维 网 的 标记 语言 \ 不 是 一 种 开发 语言 ) ， 用 来 结构 
化 信息 ， 如 标题 、 段 落 和 列表 等 ， 也 可 用 来 在 一 定 程度 上 描述 文档 的 
外 观 和 语义 ， 由 万 维 网 协会 《World Wide Web Consortium ，W3C) 维 
护 。 使 用 HTML 开 发 的 网 页 文件 扩展 名 为 .html (早期 DOS 时 代 采 用 的 
是 3 位 扩展 名 ， 扩 展 名 为 .htm) 。 目 前 主要 使 用 的 是 HTML 4.0 版 本 ， 不 
过 现在 HTML 5.0 版 本 已 经 发 布 ， 并 即将 全 面 进 入 实用 阶段 。 


HTML 使 用 一 套 标 签 (tag) 来 标记 网 页 内 容 的 格式 并 进行 排版 。 
HTML 标 记 标签 通常 称 为 HTML 标 签 (HTML tag) 。HTML 标 签 是 由 尖 
括号 (< > ) 括 起 来 的 关键 词 (关键 字 不 区 分 大 小 写 ， 但 通常 以 小 写 
表示 ) ， 比 如 <html>。 而 且 HTML 标 签 通 常 是 成 对 出 现 的 (但 不 是 所 
有 标签 都 是 成 对 的 ， 如 换行 标签 <br> 和 分 段 标 签 <p>， 它 们 只 有 一 
个 标签 ) ， 后 面 一 个 标签 前 面 要 加 上 ”“/” 符 号 ， 比 如 <b> 和 < 上 bb> ， 第 


一 个 标签 是 开始 标签 ， 第 二 个 标签 是 结束 标签， 开始 标签 和 结束 标 从 


也 称 为 开放 标签 和 闭合 标签 。 例 如 ，<i> 表示 后 面 的 字体 采用 斜体 排 
版 ，</ > 表示 此 次 采用 斜体 排版 结束 。 和 党 见 的 HTML 标 签 如 表 11-1 所 
示 。 更 详细 的 HTML 知 识 可 参见 相关 资料 。 


表 11-1 常见 HTML 标签 


标签 含义 说 明 
标记 网 页 结构 类 标签 
一 html > < /html > 标签 中 间 部 分 为 网 页 内 容 
一 head > 一 /head > 标签 中 间 部 分 为 网 页 头 部 
一 title > < /title > 标签 中 间 部 分 为 标题 内 容 
一 body > 一 /body > 标签 中 间 部 分 为 网 页 正文 
版 面 排版 类 标签 
<h#> < 到/h# > 定义 标签 中 间 部 分 内 容 标 题字 号 
< font size=# > = /font > 定义 标签 中 间 部 分 内 容 字 体 大 小 
二 font face=" 字 型 名 称 " > 二 /font > 定义 标签 中 间 部 分 内 容 字 型 
= font color=#rrggbb > = /font > 定义 标签 中 间 部 分 内 容 文 字 颜 色 
= small > < /small > 定义 标签 中 间 部 分 内 容 为 小 字体 
一 big > </big> 定义 标签 中 间 部 分 内 容 为 大 字体 
xt < 定义 标签 中 间 部 分 内 容 为 粗 体 字 
二 Sm 定义 标签 中 间 部 分 内 容 为 斜体 字 
<u> <hh> 定义 标签 中 间 部 分 内 容 为 下 画 线 字 
一 strike > < /strike > 定义 标签 中 间 部 分 内 容 为 删除 线 字 
=<sub><=/sub> 定义 标签 中 间 部 分 内 容 为 下 标 字 
< sup> = /sup > 定义 标签 中 间 部 分 内 容 为 上 标 字 
<br> 从 此 处 换行 


<p> 从 此 处 分 段 


11.2.4 HTML 文档 类 型 


上 面 讨论 的 HTML 标 记 类 文档 在 磁盘 中 保存 时 是 以 .html 作 为 文件 
扩展 名 的 。 保 存 后 ， 文 档 的 内 容 是 不 会 改变 的 ，Web 每 次 打开 这 个 文 
档 所 见 到 的 内 容 都 是 完全 一 样 的 ， 除 非 经 过 了 人 为 编辑 、 人 和 修改。 这 丈 
是 通常 所 说 的 “静态 HTML 文 档 ” 的 概念 。 


在 静 仿 HTML 文档 中 ， 网 页 内 容 是 静态 分 配 的 ， 用 户 每 次 访问 时 
所 看 到 的 内 容 是 一 样 的 。 但 这 里 要 区 分 两 个 概念 ， 那 惑 是 “静态 HTML 
文档 "与 “ 静 驴 HTML 元 素 "， 这 两 者 不 是 等 同 的 概念 ， 也 没有 一 一 对 应 
的 关系 。 也 就 是 说 ， 在 静态 HTML 文 档 中 可 以 有 像 文 本 、 图 片 之 类 的 
静态 网 页 元 素 ， 另 外 ，HTML 4.0 及 更 新 版 本 还 可 标记 图 像 、 动 画 、 


音 / 视 频 这 类 动态 网 页 元 素 。 


与 静态 HTML 文 档 相 对 的 是 动态 HTML 文 档 。 动 态 HTML 文 档 不 是 
由 管理 员 事先 制作 好 的 网 页 ， 而 是 即时 由 服务 器 应 用 程序 或 者 脚本 程 
序 ， 根 据 当前 应 用 和 用 户 提交 的 表单 数据 上 自动 生成 的 ， 其 显示 的 内 容 
是 在 不 断 变化 的 。 例 如 ， 我 们 在 网 络 购物 时 ， 每 次 在 提交 订单 时 都 会 
目 动 生成 一 个 页 面 ， 其 中 显示 了 我 们 当 次 购物 的 商品 、 人 金额 及 收 货 地 
址 信息 等 。 尽 管 整个 网 页 结构 每 次 都 是 一 样 的， 但 网 页 中 的 内 容 也 许 


每 次 都 不 一 样 ， 比 如 购物 商品 、 金额 等 信息 。 这 就 古 动态 HTML 文 
档 。 


既然 动态 HTML 文 档 不 古事 先 制作 并 保存 在 服务 器 人 磁盘 上 的 ， 开 
需要 有 专门 的 网 络 应 用 程序 来 生成 。 当 用 户 在 网 站 上 单 击 选择 了 某 类 
应 用 时 ，Web 服 务 右 束 会 调用 对 应 的 应 用 程序 ， 然 后 把 控制 权 交 给 该 
应 用 程序 。 而 该 应 用 程序 接收 用 户 在 表单 中 输入 的 数据 ， 用 户 确认 提 
交 表 单 后 应 用 程序 束 会 对 所 提交 的 数据 根据 对 应 的 网 络 应 用 程序 功能 
进行 处 理 ， 然 后 在 用 户 浏 览 絮 中 输出 处 理 的 结 采 。 由 于 用 户 每 次 提交 
的 数据 ， 或 者 应 用 环境 不 一 样 ， 所 以 可 能 每 次 最 终 从 Web 服 务 右 端 返 
回 的 页 面 内 容 都 是 不 一 样 的 ， 丈 像 我 们 每 次 在 网 站 上 购物 所 得 的 结算 
单 都 不 一 样 。 例 如 ， 在 铁道 部 网 站 得 询 车 票 时 ， 不 同时 间 得 到 的 结 
也 是 不 一 样 的 ， 因 为 每 时 每 刻 可 售票 数 都 在 变化 。 


通过 上 面 的 分 析 可 以 看 出 ， 动 态 HTML 文 档 的 创建 至 少 要 满足 两 
个 条 件 : 第 一 个 条 件 是 在 Web 服 务 器 端 要 有 能 目 动 生成 动态 HTML 文 
档 的 网 络 应 用 程序 。 这 个 读者 可 以 不 用 去 了 解 ， 因 为 在 进行 Web 服 务 
器 开发 时 ， 程 序 设计 师 会 做 这 方面 的 工作 。 第 二 个 条 件 是 Web 服务器 
要 能 将 用 户 在 表单 中 输入 的 数据 发 送 到 对 应 的 网 络 应 用 程序 ， 然 后 
Web 服 务 器 又 能 正确 地 把 应 用 程序 处 理 的 结果 以 HTML 文 档 方式 回 显 
给 用 户 。 这 就 是 一 种 逻辑 接口 一 -CGI (Common Gateway Interface， 
公共 网 关 接 口 ) 的 功能 。 


CGI 是 一 种 基于 浏览 器 的 输入 ， 并 可 在 web 服务 器 上 运行 应 用 程序 
(统称 CGI 程序 ) 的 方法 。 它 允许 web 服务 器 与 后 端 程序 及 脚本 进行 通 
信 ， 同 时 后 端 程序 和 脚本 又 可 接收 用 户 的 输入 信息 (主要 是 来 自 表 
单 ) ， 最 后 还 能 以 HTML 页 面 作为 用 户 进行 表单 提交 后 的 响应 ， 如 图 
11-3 所 示 ， 具 体 描述 如 下 (注意 其 中 的 序号 与 步骤 是 对 应 的 ) 。 


Web 服 务 需 


4) 动态 HTML 


用 户 浏览 硕 


CGI 程序 


图 11-3 利用 CGI 程序 生成 动态 HTML 文档 的 基本 流程 


1) 用 户 在 网 站 上 单 击 了 某 项 应 用 《如 单 击 购买 一 个 商品 ) 后 ， 相 
当 于 同 Web 服 务 器 提交 了 一 个 表单 。 


2) Web 服 务 器 在 收 到 用 户 提交 的 表单 后 ， 会 通过 在 服务 器 程序 设 
计 中 已 设置 好 的 关联 功能 ， 把 这 个 表单 传送 给 对 应 的 应 用 程序 (也 就 
是 CGI 程序 ) 。 


3) CGI 程序 接收 用 户 提交 的 表单 ， 并 对 其 进行 处 理 (其 中 可 能 需 
要 调用 其 他 服务 器 ， 或 者 客户 主机 ， 如 各 种 数据 库存 服务 器 ) ， 然 后 
通过 CGI 程序 的 动态 HTML 文档 生成 功能 ， 把 处 理 结果 以 一 个 自动 生 
成 的 HTML 返 回 到 Web 服 务 癸 。 


4) Web 服 务 器 再 把 这 个 自动 生成 的 HTML 回 显 到 Web 用 户 的 浏览 
= 和 5 


CGI 程序 其 实 都 是 脚本 (script) 类 程序 。“ 脚 本 ”通常 是 一 些 可 执 
行 命令 (往往 带 有 许多 参数 ) 的 集合 ， 但 需要 调用 其 他 程序 来 解释 或 
执行 ， 不 是 计算 机 可 直接 处 理 的 。 这 类 解释 或 执行 脚本 的 程序 就 是 各 
种 编程 语言 ， 特 别 是 一 些 专门 的 脚本 语言 ， 如 Perl 、JavaScript 和 


VBScript 等 。 


但 是 ，CGI 程 序 并 不 是 生成 动态 HTML 文档 的 唯一 方法 ， 还 有 一 
种 目前 广 被 采用 的 做 法 -在 HTML 页面 中 攻 入 一 些 由 编程 语言 编写 
的 脚本 (许多 编程 语言 都 可 编写 脚本 ， 如 PHP、JSP、ASP 等 ， 它 们 都 
可 以 接收 并 处 理 表单 输入 ， 同 时 与 Web 服 务 器 进行 交互 ) ， 然 后 让 
Web 服 务 器 自己 来 执行 这 些 脚 本 ， 以 便 生成 最 终 的 动态 HTML 文 档 并 
发 送 给 客户 。 这 样 一 来 ， 也 就 不 用 Web 服 务 器 调用 CGI 类 应 用 程序 了 ， 
直接 由 Web 服 务 器 来 完成 ， 效 率 更 高 。 当 然 ， 这 仅 适 用 于 一 些小 的 消 
息 类 动态 HTML 页面。 


11.2.5_ HTML 文档 的 “三 超 属性 ” 


万 维 网 中 有 3 个 " 超 * 字 非常 具有 吸引 力 ， 它 们 分 别 代表 " 超 文 
本 ”、“ 超 媒体 "和 “ 超 链接 ”。 我 们 姑且 把 它们 称 为 万 维 网 中 的 “三 超 属 
性 " 。 


“ 超 文 本 ”(HyperText) 其 实 也 是 一 种 文本 格式 ， 只 是 它 可 用 下 面 
将 要 介绍 的 “ 超 链接 ”的 方法 ， 将 保存 在 不 同位 置 的 文档 或 者 文本 信息 
组 织 在 一 起 ， 构 成 一 个 相互 天 联 的 网 状 文本 。 例 如 ， 在 访问 网 站 时 ， 
经 常见 到 有 一 些 文字 呈 不 同 颜色 (一 般 为 蓝 色 ) ， 用 鼠标 单 击 它们 后 
便 弹 出 另外 一 个 网 页 ， 或 者 消息 框 ， 用 于 解释 那 部 分 制作 链接 的 文 


de 


子 。 


“ 超 媒 体 ”(HyperMedia) 其 实 可 以 看 成 是 前 面 “ 超 文本 ”属性 的 扩 
展 ， 把 “ 超 文本 ”中 的 文本 媒体 保存 格式 扩展 到 其 他 所 有 格式 。 早 期 的 
网 站 基本 上 是 一 些 静态 甚至 纯 文 本 内 容 ， 现 在 的 网 站 的 内 容 殉 丰 宇多 
了 ， 除 了 传统 的 文本 信息 、 静 仿 图 片 外 ， 还 有 动态 图 像 、 动 画 、 音 / 视 
频 等 各 种 媒体 格式 。 而 且 ， 这么 多 种 格式 都 可 以 在 同一 个 网 站 互 存 ， 
并 可 以 相互 链接 。 但 目前 通常 是 把 “ 超 媒 体 ” 等 同 于 “ 超 文 本 ， 因 此 现 
在 的 超 文 本 标记 语言 中 不 再 只 可 以 标记 文本 格式 ， 还 可 以 标记 如 图 
片 、 图 像 、 动 画 、 音 /视频 等 各 种 媒体 格式 。 


“ 超 链接 ”(\HyperLink) 是 HTML 文 档 的 最 重要 属性 ， 是 指 从 一 个 
网 页 指 同 一 个 目标 的 连接 关系 。 这 个 目标 可 以 是 男 一 个 网 页 ， 也 可 以 
征 相 同 网 页 上 的 不 同位 置 ， 还 可 以 是 一 个 图 片 、 一 个 电子 邮件 地 址 、 
一 个 文件 ， 甚 至 是 一 个 应 用 程序 。 而 在 一 个 网 页 中 用 来 超 链 接 的 对 
象 ， 可 以 是 一 段 文本 ,或 者 是 一 个 图 片 、 图 像 、 动 画 等 媒体 。 当 济 抠 
者 单 击 已 经 链接 的 文字 或 镜片 后 ， 链 接 目 标 将 显示 在 浏览 左上， 并 且 
根据 目标 的 类 型 来 打开 或 运行 。 


一 个 网 站 包括 多 级 网 页 层次 结构 ， 如 主页 、 次 主页 (主要 是 一 些 
主要 栏目 ) 和 普通 网 页 ， 它 们 共同 构成 一 个 多 层次 的 网 站 结构 。 访 问 
网 站 时 ， 首 先 看 到 的 是 一 个 网 站 的 主页 ， 而 在 网 站 主页 中 又 会 把 下 一 
级 的 次 主页 以 超 链接 的 方式 显示 出 来 ， 这 样 用 户 就 可 以 从 网 站 主页 上 
直接 打开 次 主页 ， 在 次 主页 下 面 又 可 以 有 次 次 主页 。 因 为 一 般 对 外 公 
告 的 只 是 网 站 域名 ， 即 默认 主页 ， 因 此 ， 如 采 在 主页 中 没有 把 次 主页 
的 链接 给 出 来 ， 用 户 束 不 知道 如 何 打开 这 些 次 主页 了 。 


当然 ， 每 级 主页 下 面 义 会 有 许多 普通 的 网 页 ， 这 些 网 页 也 会 在 对 
应 级 别 的 主页 中 显示 出 来 ， 或 者 通过 网 页 中 的 一 些 关 键 字 超 链接 进入 
到 具体 的 网 页 ， 毕 竟 再 多 的 各 级 主页 也 不 可 能 把 全 部 的 网 页 都 以 超 链 
接 的 方式 显示 出 来 。 通 前 ， 在 各 级 主页 中 仅 显 示 节 新 的 普通 网 页 超 链 


全 


11.2.6 HTTP 服务 访问 基本 流程 


HTTP 是 一 个 面向 文本 (text-oriented) 的 应 用 层 协议 ， 所 使 用 的 
服务 端口 是 TCP 的 80 端 口 (这 就 是 HTTP 服 务 的 传输 层 地 址 ; ， 通 信 双 
方 承 是 在 这 个 端口 上 进行 通信 的 。 当 然 ， 这 个 端口 是 可 以 更 改 的 ， 但 
目前 互联 网 上 的 Web 服 务 器 都 是 使 用 这 个 默认 的 80 病 口 。 每 个 Web 服 
务 万 都 有 一 个 应 用 进程 ， 时 刻 监听 着 80 端 口 的 用 户 访问 请 求 。 当 有 用 
户 请 求 (以 HTTP 请 求 报 文 方式 ) 到 来 时 ， 它 会 尽快 做 出 响应 (以 
HTTPHN 应 报 文 方式 ) ， 返 回 用 户 访问 的 页 面 信息 。 当 然 ， 这 一 切 都 建 
立 在 传输 层 创建 好 对 应 的 TCP 连 接 基 础 之 上 。 


至 于 何 时 天 闭 TCP 连 接 ， 则 要 视 所 使 用 的 HTTP 版 本 而 定 。 在 
HTTP/1.0 及 以 前 版 本 中 ， 经 历 每 一 个 请 求 -应 答 过 程 后 就 会 关闭 所 使 用 
的 TCP 连 授 ， 单 击 新 的 链接 后 又 会 重新 建立 新 的 TCP 连 授 。 这 种 HTTP 
服务 方式 称 为 非 持 续 连 接 (no-persistent connection) 。 而 在 HTTP/1.1 
版 本 以 后 ，HTTP 人 允许 在 同一 个 TCP 连 接 基 础 上 访问 同一 网 站 服务 器 上 
的 多 个 不 同 页 面 ， 仅 当 用 户 关闭 对 应 的 网 站 时 ， 对 应 的 网 站 TCP 传 输 
连接 才 关闭 ， 称 为 持续 连接 (persistent connection) 。 持 续 连 接 模 式 的 
Web 服 务 访问 的 基本 流程 如 图 11-4 所 示 。 


二 Ew > 


> 用户。 ”web 服务 器 攻 


TCP 连接 建立 
HTTP 请 求 报 文 


HTTP 响应 报 文 


TCP 连接 关闭 


ELE 


11-4 持续 连接 模式 的 web 服务 访问 的 基本 流程 


从 图 11-4 中 可 以 看 出 ，HTTP 服 务 的 访问 主要 是 指 HTTP 消 息 的 传 
递 ， 其 中 包括 Web 用 户 同 Web 服 务 句 提交 的 HTTP 请 求 报 文 和 和 Web 服务 
狼 同 Web 用 户 返 回 的 HTTP 啊 应 报 文 。 下 面 完 综合 了 解 一 HTTP， 然 
后 再 具体 了 解 其 报 文 结构 。 


11.2.7 HTTP 的 主要 特性 


HTTP 是 一 个 属于 应 用 层 的 面向 对 象 的 协议 ， 由 万 维 网 协会 
(W3C) 和 Internet 工 作 小 组 〈Internet Engineering Task Force，IETF) 
于 1990 年 合作 开发 。1997 年 前 使 用 的 是 RFC1945 中 所 定义 的 HITP/1.0 
版 本 ，1998 年 后 使 用 的 是 其 更 新 版 本 RFC2616， 即 HTTP/1.1 版 本 。 
HTTP 规 是 了 Web 客 户 闻 与 Web 服 务 右 之 间 的 报 文 交互 方式 ， 其 报 文中 
的 每 个 字段 都 是 一 些 ASCII 字 符 串 ， 而 且 各 个 字段 的 长 度 都 是 不 固定 
的 。 


总 体 来 说 ，HTTP 具 有 以 下 几 方 面 的 特性 : 
(1) 客户 端 /服务 器 (C/S) 模式 


C/S 模 式 是 所 有 网 络 应 用 服务 采用 的 通用 模式 。Web 客 户 只 需要 使 
用 文 持 HTTP 的 客户 端 程序 《各 种 浏 贤 郁 ) ， 束 可 以 访问 由 不 同 Web 服 
务 絮 程序 开发 的 Web 网 站 。 


(2) 无 连接 


这 里 所 说 的 “无 连接 ”是 指 在 进行 Web 应 用 前 无 须 建立 专门 的 HTTP 
应 用 层 会 话 连 搂 ， 仅 需要 直接 利用 传输 层 已 为 它 建立 好 的 TCP 传 输 连 


接 即 可 ， 而 像 Telnet、SMTP、POP3 这 类 应 用 协议 ， 是 面向 连接 的 ， 除 
了 需要 传输 层 的 TCP 连 接 外 ， 它 们 自己 还 要 建立 会 话 连接 。 


i} 


(3) 高 可 靠 性 


虽然 HTTP 本 吴 是 不 可 靠 的 无 连接 协议 ， 但 它 使 用 了 可 靠 的 TCP 传 
输 层 协议 ， 在 进行 HTTP 传 输 之 前 ， 已 建立 了 可 靠 的 TCP 连 接 ， 因 此 ， 
从 数据 传输 角度 来 讲 ，HTTP 的 报 文 传输 仍 是 可 靠 的 。 


(4) 无 状态 


这 里 所 说 “无 状态 ”是 指 同一 客户 第 二 次 访问 同一 Web 服务 右上 的 
同一 页 面 时 ， 服 务 器 给 客户 端的 啊 应 与 第 一 次 是 一 样 的 〈 当 然 ， 这 是 
假设 Web 服 务 器 上 的 对 应 页 面 没有 更 新 ，，Web 服 务 器 不 会 记 住 这 个 
客户 端 曾经 访问 过 这 个 页 面 ， 而 做 出 任何 其 他 啊 应 。 


(5) 简单 快速 


客户 端 通过 HTTP 访 问 Web 服 务 器 时 ， 只 需 传 送 请 求 方法 和 路 径 。 
请 求 方法 常用 的 有 GET、HEAD、POST 等 (具体 内 容 将 在 本 章 后 面 介 
绍 ) ， 每 种 方法 规定 了 客户 端 与 服务 器 之 间 进 行 的 事务 处 理 和 消息 类 
型 。 由 于 HTTP 简 单 ， 使 得 HTTP 服 务 器 的 程序 规模 小 ， 因 而 通信 速度 
可 以 很 快 。 


从 图 11-4 可 以 看 出 ，HTTP 报 文 分 为 请 来 报 文 和 啊 应 报 文 两 类 ， 分 
别 用 于 Web 客 户 端 发 起 的 HTTP 应 用 请 求 和 Web 服 务 器 对 客户 端 所 做 出 
的 HTTP 应 用 啊 应 。 下 面 将 分 别 介绍 这 两 种 HTTP 报 文 格式 。 


11.2.8 HTTP 请求 报 文 格式 


在 建立 好 TCP 传 输 连接 后 ，Web 客 户 端 首先 要 进行 的 是 向 Web 服 务 
器 发 送 HTTP 请 求 报 文 ， 请 求 打开 指定 的 网 站 或 页 面 。 一 个 HTTP 请 求 
报 文 包括 请 求 行 (request line) 、 请 求 头 部 (request header) 行 、 空 行 
和 实体 主体 (entity body) 行 4 个 部 分 ， 如 图 11-5 所 示 。HTTP 报 文 
(HTTP 请 求 报 文 和 11.2.9 节 将 要 介绍 的 HTTP 响 应 报 文 ) 中 各 字段 是 没 
有 固定 长 度 的 。 下 面 对 这 4 个 组 成 部 分 分 别 进行 说 明 。 
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图 11-5 _ HTTP 请求 报 文 格式 


HTTP 请 求 报 文中 的 “请 求 行 " 是 由 “请 求 方法 "”、“URL” 和 “协议 版 
本 ”3 个 字段 组 成 的 ， 它 们 之 间 均 以 空格 进行 分 隔 。 这 部 分 是 必 不 可 少 
的 。 在 请 求 行 的 最 后 有 一 个 回 车 控制 符 和 一 个 换行 控制 符 (一 起 
以 “CRLEF” 表 示 ) ， 使 下 面 的 请 求 头 部 信息 在 下 一 行 显示 。 


“请 求 方法 ”字段 指示 本 请 求 报 文中 所 使 用 的 HTTP 操 作 (其 实 就 是 
指 所 使 用 的 HTTP 命 令 ) ， 具 体 如 表 11-2 所 示 (注意 ， 全 是 大 写字 母 ， 
不 能 为 小 写 ) 。 其 中 最 常用 的 是 GET 和 POST 这 两 种 方法 。 
表 11-2 HTTP 请 求 方法 


请 求 方法 含义 说 明 
请 求 服务 器 发 送 在 URL 字段 中 指定 的 Web 页 面 。URL 的 根部 分 是 相对 服务 器 的 根 目录 的 ， 总 


GET rb 

以 “/” 前 级 开始 ， 下 同 

HEAD 请 求 读 取 URL 字段 指定 的 Web 页 面 的 头 部 信息 ， 而 不 是 全 部 的 Web 页 面 。 利 用 这 一 方法 可 以 
得 到 一 个 页 面 的 最 后 修改 时 间或 者 其 他 头 部 信息 

PUT 请 求 在 URL 路 径 下 存储 一 个 Web 页 面 ， 与 PUT 方法 相反 

pOST 在 URL 所 指定 的 Web 服务 器 后 面 附加 一 个 以 URI 格式 命名 的 资源 ， 以 便 可 以 为 Web 服务 器 提 
供 更 多 的 信息 ， 如 在 服务 器 上 张贴 一 条 海报 消息 

( 续 ) 
请 求 方法 含义 说 明 

DELETE 删除 URL 字段 指定 的 Web 页 面 ， 当 然 最 终 能 否 删 除 成 功 还 会 受到 用 户 权 限 的 限制 

TRACE 指明 这 是 一 个 用 来 进行 环 回 测试 的 请 求 报 文 ， 用 于 调试 

CONNECT 用 于 连接 代理 服务 器 

OPTIONS 请 求 查询 一 些 特定 的 选项 信息 


例如 ，“GET http://winda.blog.51cto.com/55153/815617 HTTP/1.1” 是 
请 求 打 开 作 者 在 51CTO 博 客 上 的 一 篇 文章 ， 其 中 GET 是 请 求 方法 ， 中 
司 部 分 是 URL，HTTP/1.1 是 使 用 的 HTTP 版 本 ， 且 它们 三 者 之 间 用 空格 


分 B 


2. 请 求 头 部 行 


HTTP 请 求 头 部 包括 一 系列 的 “请 求 头 ”和 它们 所 对 应 的 值 ， 指 出 多 
许 客 户 站 癌 服 务 套 传递 请 求 的 附加 信息 以 及 客户 站 目 身 的 信息 。 当 打 
开 一 个 网 页 时 ， 浏 咒 紫 要 同 网 站 服务 器 发 送 一 个 HTTP 请 求 涉 ， 然 后 网 


站 服务 亏 根 据 HTTP 请 求 头 的 内 容 生成 当 次 请 求 的 内 容 并 发 送 给 浏 贤 
砷 ， 这 束 是 HITP 请 求 报 文中 的 “请 求 头 ”的 作用 。 


HTTP 请 求 报 文 的 “请 求 头 部 ”是 由 一 系列 的 行 组 成 的 ， 每 行 包 括 “ 尖 
部 字段 名 ”和 * 值 ?两 个 字段 ， 它 们 之 间 用 英文 冒号 “:" 分 隔 ， 但 也 可 以 没 
有 “请 求 头 部 ”。 每 一 行 的 最 后 都 有 一 个 回 车 控制 符 和 一 个 换行 控制 符 
(一 起 以 “CRLF” 表 示 ) ， 使 下 一 个 请 求 头 在 下 一 行 显示 。 许 多 请 求 头 
都 允许 客户 端 指定 多 个 可 接收 的 " 值 ?字段 选项 ， 有 时 甚至 可 以 对 这 
些 “ 值 ?字段 选项 进行 排 省 ， 多 个 选项 间 以 喜 号 分 隔 。 典 型 的 HTTP 请 求 


头 如 表 11-3 所 示 。 
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Date 
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表 11-3 ”典型 的 HTTP 请 求 头 
含义 说 明 
指定 客户 端 能 处 理 的 MIME (Multipurpose Internet Mail Extension， 多 用 途 互 联网 邮件 


扩展 ) 页 面 类 型 。 例 如 ，Accept : image/gif， 表 明 客 户 端 希望 接受 GIF 图 像 格式 的 资源 ; 
Accept: text/html， 表 明 客户 端 希望 接受 HTML 文本 


指定 客户 端 可 以 接受 的 字符 集 。 例 如 ，Accept-Charset:iso-8859-1,gb2312， 表 示 客 户 端 可 
以 接受 的 字符 集 在 所 列 的 两 个 标准 中 。 如 果 在 请 求 消息 中 没有 设置 这 个 请 求 头 ， 默 认 是 任何 
字符 集 都 可 以 接受 

指定 客户 端 能 进行 解码 的 数据 编码 方式 。 例 如 ，Accept-Encoding:gzip，compress， 表 示 客 
户 可 以 接受 gzip 和 compress 两 种 编码 格式 。 如 果 请 求 消 息 中 没有 设置 这 个 请 求 头 ， 那 么 服 
务 器 假定 客户 端 可 以 接受 各 种 内 容 编码 

指定 客户 端 能 处 理 的 语言 类 型 。 例 如 ，Accept-Language:zh-cn， 表 示 客 户 端 只 接受 中 文 简 
体 。 如 果 请 求 消息 中 没有 设置 这 个 请 求 头 ， 那 么 服务 器 假定 客户 端 对 各 种 语言 都 可 以 接受 

指定 客户 端 信任 的 凭据 列表 。 当 浏览 器 访问 一 个 页 面 时 ， 如 果 收 到 服务 器 的 响应 代码 为 
401 (未 授权 )， 那 么 可 以 发 送 一 个 包含 Authorization 请 求 报头 域 的 请 求 ， 要 求 服务 器 对 所 列 
的 用 户 账 户 进行 验证 


将 一 个 以 前 设置 的 Cookie 送 回 给 服务 器 
请 求 采用 持续 连接 方式 。 例 如 ，Connection:Keep-Alive 
指定 消息 发 送 时 的 日 期 和 时 间 。 例 如 ，Date: Tue, 11 Jul 2012 18:23:51 GMT 


( 续 ) 
含义 说 明 

向 服务 器 请 求 一 个 电子 邮箱 地 址 。 例 如 ，From : winda@microsoft.com， 这 是 假设 作者 在 
访问 微软 网 站 时 向 微软 的 服务 器 申请 的 一 个 电子 邮箱 地 址 

指定 被 请 求 服务 器 的 域名 和 端口 ， 如 果 使 用 默认 的 80 端口 ， 则 可 以 省 略 端 口 指 定 步 又 。 
例如 ，Host ; www.51cto.com， 表 示 请 求 的 服务 器 域名 为 www.51cto.com， 且 使 用 默认 的 
TCP 80 端口 进行 访问 

包括 一 条 URI 信息 ， 要 求 从 指定 的 URI 中 访问 当前 请 求 的 页 面 

允许 客户 端 将 它 的 操作 系统 、 浏 览 器 和 其 他 属性 告知 服务 器 。 例 如 ， 上 网 登录 论坛 的 时 
候 ， 往 往 会 看 到 一 些 欢迎 信息 ， 其 中 列 出 了 登录 者 的 操作 系统 的 名 称 和 版 本 ， 以 及 他 所 使 用 
的 浏览 器 的 名 称 和 版 本 ， 这 就 是 User-Agent 请 求 头 的 “功劳 ”了 

客户 端 希望 切换 到 新 的 协议 


在 HTTP 请 求 报 文 的 最 后 一 个 请 求 头 后 是 一 个 空 行 ， 发 送 回 车 符 和 
换行 符 (一 起 以 <CRLF” 表 示 ) ， 通 知 服务 器 以 下 不 再 有 请 求 头 。 


4. 实 体 主 体 行 


请 求 报 文中 “实体 主体 ”部 分 通 当 是 不 用 的 。 它 不 能 在 GET 方 法 中 使 
用 ， 仅 在 POST 方法 中 用 于 同 服 务 套 握 供 一 些 用户 攒 据 信 息 。 


下 面 是 一 个 HTTP 请 求 报 文 示例 : 


POST/servlet/default.,jsp HTTP/1.1 !--- 这 是 一 个 POST 方法 请 求 行 ， 指 出 了 
所 附加 的 消息 的 URL 和 所 用 的 HTTP 版 本 为 1.1 

Accept-Language:zh-cn,zh !--- 指定 客户 端 可 以 接受 的 语言 

Accept-Charset:GB2312,utf-8 !--- 指定 客户 端 可 以 接受 的 字符 集 为 GBB2312 和 
utf-8 

Accept:text/html,application/xhtml+xml,application/xml !--- 指定 客 
户 端 浏览 器 支持 的 MIME 类 型 分 别 是 text/html、application/xhtml+xml、 
application/xml 

Accept-Encoding:gzip,deflate !--- 指定 客户 端 浏览 器 支持 的 压缩 编码 格式 为 
gzip 和 deflate 

User-Agent:Mozilla/5.0 !--- 指定 客户 端 使 用 的 浏览 器 为 Mozil1a 5.0 版 本 

Host :www.51cto.com !--- 指定 客户 端 要 访问 的 服务 器 域名 为 www.51cto.com 

Connection:Keep-Alive !--- 指定 采用 持续 连接 方式 

(这 里 有 一 个 空 行 ) 
User=winda&pwd=1234 !--- 此 行为 向 服务 器 提交 的 用 户 账户 为 wnijnda， 密 码 为 


1234 


11.2.9 ” HTTP 响应 报 文 格式 


Web 服 务 器 收 到 客户 端 发 来 的 HTTP 请 求 报 文 ， 通 过 服务 器 处 理 后 
会 返回 一 个 HTTP 响应 报 文 给 请 求 的 客户 端 ， 以 告知 客户 端 Web 服 务 器 
对 客户 端 请 求 所 做 出 的 处 理 。 如 是 否 允 许 此 次 请 求 的 HTTP 连 接 ， 出 现 
了 什么 连接 错误 ， 错 误 代 码 和 错误 原因 等 。HTTP 响 应 报 文 也 是 由 四 部 
分 组 成 ， 分 别 是 响应 行 (Response) 、 响应 头 部 (Response Header) 
了 、 空 行 和 实体 主体 行 ， 如 图 11-6 所 示 。 


办 议 版 本 | 空 状态 码 “| 空 沁 术 短语 | 回 车 换行 < 响应 行 
头 部 字段 4 : | 回 车 | 换行 
和 工 | 控制 符 | 控制 符 
响应 头 部 行 
冒号 大人 前 六 浊 垢 
3 Et A 回 车 换行 
人 | 人 控制 符 | 控制 符 
回 车 控制 符 | 换行 控制 符 空 行 
让 < 实体 主体 行 


图 11-6 _ HTTP 响应 报 文 格式 


HTTP 曙 应 报 文中 的 “ 空 行 ?部 分 只 有 一 个 回 车 控制 符 和 一 个 换行 控 
制 符 ， 其 目的 束 是 空 一 行 显示 下 面 的 主体 信息 。“ 实 体 主 体 行 ”部 分 也 


基本 不 用 。 下 面 分 别 介绍 “响应 行 ? 和 "响应 头 部 行 ”。 
1. 响 应 行 


在 HTTP 了 咯 应 报 文 的 “ 咯 应 行 ”中 主要 有 3 个 了 字段， 分别 是 “协议 版 
本 ”、“ 状 态 码 ” 和 “ 插 述 短语 ”， 它 们 之 间 用 空格 分 阳 。 最 后 还 有 一 个 回 
车 控制 符 和 一 个 换行 控制 符 〈 一 起 用 "CRLF” 表 示 ) 。 其 中 “协议 版 
本 ”字段 用 来 显示 Web 服 务 器 使 用 的 HTTP 版 本 。“ 状 态 码 ”字段 比较 重 
要 。 它 用 一 个 3 位 数 表示 不 同 的 状态 ， 如 请 求 是 否 被 接受 ， 如 和 没有 衫 
接受 原因 是 什么 ， 共 有 5 组 取 值 ， 如 表 11-4 所 示 。“" 描 述 短语 "字段 是 对 
应 状态 码 的 简短 摘 述 。 


表 11-4 HTTP 响应 报 文中 的 “状态 码 ” 类 型 


NE A 


lxx 指示 类 响应 ， 表 示 请 求 已 接收 ， 继 续 处 理 | ”100= 服务 器 同意 处 理 客户 请 求 
2xx 成 功 类 响应 ， 表 示 请 求 已 被 成 功 接受 200= 请 求 成 功 ，204= 无 内 容 ， 也 表示 请 求 成 功 
重 定向 类 响应 ， 表 示 要 完成 请 求 必须 进行 i 
3x) 301= 指示 1 重 定 后 
更 进一步 的 操作 指示 页 面 已 重 定向 了 
.mvuwe psn | 400= 客 户 请 求 有 语法 错误 ， 不 能 被 服务 器 所 理 
1 闪 错 了 啊 应 EE 示 客 户 端 请 5 吾 和 i ES 
人 解 ，401= 请 求 未 经 授权 ; 403= 服务 器 收 到 请 求 ， 
, a 但 拒绝 提供 服务 ，404= 请 求 资源 不 存在 
es 服务 器 端 错误 类 响应 ， 表 示 服 务 器 未 能 实 500- 服务 各 发 生 了 不 可 项 期 的 铺 误 ， 503= 服务 


瑞 所 需 的 请 求 器 当前 不 能 处 理 客户 端的 请 求 ， 过 一 段 时 间 再 斌 


“ 呵 应 行 * 的 最 后 也 是 一 个 回 车 控制 循 和 一 个 换行 控制 符 ， 然 后 换 
进入 到 下 面 的 “h 啊 应 头 部 行 ” 部 分 。 


2. 响 应 头 部 行 


HTTP 啊 应 报 文 中 的 “ 虽 应 头 部 行 ” 允 许 服 务 器 传递 不 能 放 在 状态 行 
中 的 附加 响应 信息 ， 以 及 关于 服务 器 的 信息 和 对 URI 所 标识 的 资源 进行 
下 一 步 访 问 的 信息 。 


HTTP 啊 应 报 文 的 “ 啊 应 头 部 行 ?由 一 系列 行 组 成 ， 
段 名 ”和 “ 值 ? 两 个 字段 ， 它 们 之 间 用 英文 冒号 “” 分 隔 。 每 一 行 的 最 后 都 
有 一 个 回 车 控制 符 和 一 个 换行 控制 符 ， 使 下 一 个 啊 应 头 在 下 一 行 显 
示 。 许 多 啊 应 头 痢 允许 服务 絮 指 定 多 个 妈 回 的 “ 值 ”字段 计 项 ， 有 时 其 
至 可 以 对 这 些 选项 的 “ 值 ?字段 选项 进行 排名 ， 多 个 选项 间 以 “分 隔 。 
典型 的 HTTP 啊 应 头 如 表 11-5 所 示 。 


每 行 包括 < 头 部 字 


响应 头 
Allow 


Server 


Content-Encoding 
Content-Language 


Content-Length 


Content-type 
Date 
Last-Modified 
Location 


Accept-Range 


Refresh 


Set-Cookie 
Upgrade 


表 11-5 典型 的 HTTP 响应 头 
含义 说 明 

显示 服务 器 支持 哪些 请 求 方法 
显示 服务 器 的 软件 信息 。 
Apache-Coyote， 版 本 为 1.1 
显示 请 求 文档 采用 的 编码 方法 。 

= 方式 

EE 页 面 使 用 的 语言 。 例 如 ，Content-Language: zh/zh-cn， 表 示 页 面 支持 的 语言 


示 请 求 页 面 的 长 度 〈 以 字 节 为 单位 )。 例 如 ，Content-Length : 1024， 表 示 页 面 大 小 为 
a 守节 


显示 页 面 支持 的 MIME 类 型 。 
HTML 两 种 消息 类 型 
指定 消息 发 送 时 的 日 斯 和 时 间 。 例 如 ，Date: Tue, 11 Jul 2012 18:23:51 GMT 


显示 请 面 最 后 被 编辑 或 修改 的 日 期 和 时 间 。 例 如 ，Last-Modified : Tue, 11 Jul 2012 
12:11:51 GM 


指示 客户 端 将 请 求 发 送 到 指定 的 位 置 ， 起 到 重 定向 的 作用 

显示 服务 端 器 将 接受 指定 字 节 范围 内 的 请 求 。 例 如 ，Accept-Range : 
只 接受 1024 字 节 以 内 的 请 求 

指示 客户 端 多 少 秒 后 再 刷新 或 者 重新 访问 本 页 面 。 例 如 ，Refresh : 
秒 后 再 刷新 或 访问 本 页 面 

指示 客户 端 设置 和 页 面 关联 的 Cookie 

服务 器 希望 切换 到 新 的 协议 


例如 ，Server : Apache-Coyote/1.1， 表 示 Web 服务 器 软件 为 


例如 ，Content-Encoding : gzip， 表 示 文 档 采 用 的 是 gzip 


例如 ，Content-type : text/html， 表 示 页 面 支持 text 和 


1024， 表 示 服 务 器 


5， 表 示 要 客户 端 过 5 


下 面 是 一 个 HTTP 响 应 报 文 的 示例 。 


HTTP/1.1 200 0K !--- 这 是 一 个 HTTP 响 应 报 文 状 态 行 ， 显 示 的 协议 版 本 为 
HTTP/1.1， 表 示 请 求 成 功 

Server:Microsoft-IIS/6.0 !--- 表示 服务 器 

Date:Sun,3 Jan 2012 13:13:33 GMT !--- 表示 服务 器 发 送 此 响应 报 文 的 日 期 和 
时 间 

Content-Type:text/html !--- 指示 所 请 求 页 面 文 持 的 MIME 类 型 为 text 和 HTML 

Last-Modified:Mon,14 Apr 2012 13:23:42 GMT !--- 指示 所 请 求 页 面 的 最 后 
修改 日 期 和 时 间 


驴 


Content -Length:112 !--- 指示 服务 器 接受 前 112 个 字 节 的 请 求 内 


11.3 DNS 服务 


DNS (Domain Name System， 域 名 系统 ) 是 一 种 把 计算 机 主机 名 
称 解 析 为 对 应 的 了 地 址 的 服务 。 在 UNIX 和 Linux 操 作 系统 中 的 DNS 服 
务 通常 称 为 BIND (Berkeley Internet Name Domain Service， 伯 克利 因 
等 网 名 称 域 服务 ) 。 但 要 特别 说 明 的 是 ， 从 网 络 通信 原理 上 来 讲 ， 
DNS 并 不 是 必需 的 ， 因 为 可 以 直接 通过 耳 地址 进行 访问 ， 而 且 事实 上 
网 络 通 信 时 最 终 所 采用 的 寻 址 方式 也 是 网 络 层 的 IP 地 址 寻 址 。 下 面 先 
来 介绍 一 下 DNS 技术 的 引入 背景 。 


11.3.1 DNS 扩 术 的 引入 表 景 


为 什么 要 引入 DNS 服 务 ? 首先 让 我 们 回顾 一 下 数据 通信 的 基本 原 
理 。 


在 介绍 传输 层 服 务 时 ， 我 们 提 到 过 应 用 层 的 Socket ( 套 接 字 ) 服 
务 。 套 接 字 是 也 地址 和 端口 号 的 组 合 ， 中 间 用 冒号 或 逗号 分 隔 ， 如 
(192,168.10,80) 。 每 个 TCP 传 输 连 接 有 两 个 端点 ， 也 就 是 有 两 个 套 
接 字 ， 即 “ 源 耳 地址 和 端口 号 ?组 合 和 * 目 的 耳 地 址 和 端口 号 组合， 可 
表示 为 { socketl,socket2 ) ， 或 者 { (IP1,Port1) ，(IP2,Port2) 上 。 其 
中 的 “PP 地 址 是 主机 的 网 络 层 地 址 ， 用 来 在 局 域 网 或 广域网 中 对 各 节 


点 进行 唯一 标识 《当然 ， 局 域 网 和 广域网 可 使 用 的 耻 地 址 范围 是 不 一 
样 的 ， 具 体 参 见 本 书 第 7 草 有 关 局 域 网 耻 地 址 和 公 网 耳 地址 的 相关 内 
容 ) ， 而 “端口 号 ? 则 是 为 每 个 应 用 进程 所 分 配 的 传输 层 地 址 。 在 同一 
时 间 内 ， 两 台 主 机 间 可 以 运行 多 个 网 络 应 用 ， 每 个 进程 需要 用 一 个 端 
口 来 进行 唯一 区 分 (因为 此 时 多 个 应 用 进程 中 的 源 IP 地 址 和 目的 IP 地 
址 都 是 一 样 的 ) 。 


1.IP 地 址 标识 的 不 足 


在 应 用 层 要 访问 目的 主机 时 ， 不 仅 要 指出 该 目的 主机 的 网 络 层 IP 
地 址 (用 于 网 络 寻 址 ) ， 还 要 指出 在 传输 连接 中 使 用 的 端口 号 ， 以 及 
在 应 用 层 使 用 的 应 用 协议 。 例 如 ， 在 访问 Web 服 务 器 时 ， 需 要 在 用 户 
浏览 器 地 址 栏 中 输入 类 似 http://118.144.78.54:80 的 地 址 ， 其 中 ，http 是 
访问 Web 服 务 器 时 使 用 的 应 用 层 HTTP，118.144.78.54 是 对 应 Web 服 务 
器 的 耳 地 址 ，80 是 对 应 Web 服 务 器 应 用 进程 传输 层 端口 号 (当然 ， 如 
果 是 常规 服务 ， 那 么 这 个 端口 号 是 不 用 输入 的 ) 。 


从 上 述 内 容 可 以 看 出 ， 使 用 IP 地 址 来 运行 各 种 网 络 应 用 是 完全 没 
问题 的 。 但 对 于 那些 位 于 互联 网 上 ， 供 全 球 用 户 公开 访问 的 各 种 公用 
服务 器 来 说 ， 这 种 IP 地 址 标识 方式 存在 以 下 几 方 面 的 不 足 : 


(1) 不 便 记 忆 


尽管 现在 把 了 地 址 以 比较 简单 的 十 进 制 表示 ， 在 浏览 锅 地 址 栏 中 
也 是 以 十 进 制 格式 表示 IP 地 址 的 ， 其 长 度 也 不 是 很 长 (十进制 IPv4 地 
址 最 长 也 仅 为 12 位 ) ,但 是 它 远 没有 普通 的 名 称 好 记 ， 就 像 要 记 一 个 
人 的 吴 份 证 号 要 远 比 记 一 个 人 的 名 字 困 难 一 样 ， 哪 介 身 份 证 号 只 有 短 
短 的 几 位 。 


当然 ， 以 上 是 针对 现在 仍 广 泛 使 用 的 IPv4 地 址 来 说 的 ， 对 于 长 度 
为 现行 IPv4 地 址 4 倍 的 IPV6 地 址 ， 这 方面 的 不 足 就 更 为 明显 了 。 


(2) 不 方便 地 址 变更 


Web 服 务 右 ， 特 别 是 互联 网 上 Web 服 务 器 的 卫 地 址 可 能 会 因 各 种 原 
因而 变更 。 如 有 果 采 用 IP 地 址 进行 标识 的 话 ， 那 么 耻 地 址 的 每 次 变更 对 
于 这 种 开放 型 的 互联 网 服务 器 来 说 可 能 是 致命 的 打击 ， 因 为 有 那么 多 
已 知 或 未 知 的 用 户 ， 不 可 能 一 一 都 通知 到 。 但 如 果 采 用 的 是 网 站 服务 
妖 名 称 来 进行 标识 ， 那 么 IP 地 址 如 何 变 化 都 没有 影响 ， 只 要 服务 右 主 
机 名 称 不 变 即 可 。 


(3) .不 安全 


如 果 直 接 把 网 站 服务 器 的 IP 地 址 对 外 暴露 ， 那 么 这 显然 不 是 一 个 
安全 的 做 法 ， 因 为 这 很 可 能 被 一 些 别有用心 的 人 利用 〈 守 取 公 网 中 地 
址 、 盗 链接 等 ) 。 尽 管 对 一 些 专业 黑客 来 说 ， 无 论 如 何 做 好 安全 防范 


工作 ， 要 想 获 取 服 务 器 IP 地 址 都 十 一 件 容易 的 事 ， 但 防范 总 好 过 不 防 


范 。 


2.host 文 件 名 称 解 析 方 案 


为 了 克服 以 上 IP 地 址 标识 方案 的 不 足 ， 于 是 有 人 想到 使 用 更 方便 
记忆 的 服务 器 名 称 来 奉 代 服务 器 IP 地 址 。 在 引入 DNS (1987 年 引入 ) 
之 前 的 ARPANet 〈 互 联网 的 前 身 ) 中 ， 通 过 一 个 称 为 host.txt 的 文本 文 
件 把 网 络 中 各 计算 机 的 计算 机 名 称 与 其 对 应 的 IP 地 址 一 一 列 出 ， 以 此 
实现 解析 。 在 host 文 件 的 IP 地 址 和 计算 机 名 映射 表 项 中 ， 前 面 是 IP 地 
址 ， 后 面 是 对 应 的 计算 机 主机 名 《最 初 仅 是 像 我 们 通常 所 说 的 
NetBIOS 格 式 计 算 机 名 ) ， 每 个 映射 独占 一 行 。 格 式 如 下 (以 下 仪 为 
示例 ， 并 非 真 实 的 映射 ) : 


127.0.0.1 localhost !--- 此 为 本 地 计算 机 环 路 映射 
196.168.1.109 microsoftdesk 
202.16.83.15 sunfinal 


然后 ， 由 各 计算 机 调用 这 个 host 文 件 以 实现 从 计算 机 名 到 了 地 址 

的 解析 。 这 个 host 文 件 当 时 是 由 专门 的 一 台 或 多 台 服 务 名 进行 管理 的 

(其 实 ， 在 Windows、Linux 和 UNIX 系 统 主机 上 也 有 这 个 文件 ， 仅 用 

于 本 地 计算 机 上 的 名 称 解 析 ) 。 当 然 ， 这 是 在 没有 使 用 DNS 域名 情况 

下 的 映 射 (主要 用 于 局 域 网 中 ) ， 在 使 用 了 DNS 域名 时 ， 后 面 的 计算 
机 名 也 可 以 是 DNS 域名 格式 。 


随 看 互联 网 上 计算 机 的 增加 ， 人 们 发 现 以 上 这 种 通过 host 文 件 进 
行 名 称 解 析 的 方案 至 少 存在 以 下 两 方面 的 不 足 : 


(1) 名 称 冲 突 在 所 难免 


因为 没有 一 种 可 以 限制 名 称 冲突 的 机 制 ， 所 以 各 公司 在 为 自己 的 
服务 器 起 名 时 就 难免 与 其 他 公司 的 服务 器 计算 机 各 发 生 冲突 。 就 像 每 
个 人 的 姓名 一 样 ， 在 全 国 范围 来 讲 ， 同 名 的 人 不 知 有 多 少 ， 因 为 没有 
规定 不 允许 同名 。 


(2) 少数 名 称 解 析 服 务 器 难以 承受 


随 看 互联 网 上 服务 吉 数 的 飞速 增加 ， 仅 靠 授 权 机 构 中 少数 通过 调 
用 host 文 件 进行 名 称 解 析 的 名 称 服务 占 根 本 无 法 承受 如 此 大 的 人 负 答 。 


3.DNS 名 称 解 析 方 案 


为 了 解决 以 上 host 文 件 名 称 解 析 方 案 中 的 不 足 ， 人 们 开发 了 基于 
域 (这 里 的 “ 域 " 是 指 “ 域 名 ”) 的 分 层 命名 方案 一 -DNS。DNS 可 以 将 
主机 名 映射 成 对 应 的 IP 地 址 ， 其 基本 的 名 称 解析 原理 如 下 。 


当 一 个 应 用 进程 需要 把 主机 名 解析 为 IP 地 址 有 时， 首先 该 应 用 程序 
就 调用 一 个 解析 器 (resolver) ， 使 它 成 为 DNS 客户 ， 将 该 主机 名 作为 
DNS 请 求 报 文 参数 ， 以 UDP 用 户 数据 报 方式 发 送 给 本 地 DNS 服务 大 。 
然后 ， 本 地 DNS 服务 器 得 找 该 主机 名 ， 并 且 将 找到 的 下地 址 放 在 响应 


报 文 中 返回 给 解析 器 。 解 析 器 再 将 IP 地 址 返回 给 调用 解析 器 的 应 用 进 
程 ， 这 样 应 用 进程 束 可 以 根据 所 得 到 的 目的 IP 地 址 进行 通信 了 。 当 
然 ， 可 能 会 存在 本 地 DNS 服 务 右 不 能 解析 所 请 求 的 主机 名 的 情况 ， 这 
时 本 地 DNS 服 务 锅 就 仅 为 一 个 DNS 代 理 角 色 ， 然 后 它 可 以 把 这 个 解析 
工作 交 给 在 本 地 服务 器 上 配置 的 其 他 相关 联 的 DNS 服 务 嚣 。 以 上 就 古 
DNS 服 务 器 的 “转发 如 ”功能 。 


11.3.2 ”DNS 命名 方案 的 设计 思想 


从 设计 思想 上 来 看 ， 开 发 DNS 命 名 方案 束 是 想 通 过 某 种 方法 解决 
host 名 称 解析 方案 中 “容易 发 生 名 称 冲突 和 “服务 句 解 析 性 能 不 足 ” 两 方 
面 的 问题 。 这 个 方案 是 采用 基于 域名 的 分 层 命名 方案 。 下 面具 体 分 析 
这 一 命名 方案 是 如 何 解决 这 两 方面 问题 的 。 


1. 名 称 冲 突 的 解决 方案 


目前 ， 计 算 机 名 主要 有 两 种 格式 ， 一 种 是 像 早 期 host 文 件 中 那样 
的 非 分 级 的 单一 字符 串 所 代表 的 本 地 计算 机 名 称 ， 如 webserver; 另 一 
种 是 以 DNS 域名 为 基础 的 域 网 络 中 的 DNS 名 称 ， 如 
webserver.lycb.com， 后 面 的 “lycb.com” 是 一 个 域名 。 完 整 的 DNS 名 称 
(webserver.lycb.com) 代表 的 是 在 lycb.com 域 中 的 一 台 名 为 webserver 


的 服务 右 。 


注意 ”其 实 ，DNS 域 名 的 最 后 面 还 有 一 个 小 圆 点 ， 代 表 的 是 根 域 
名 ， 只 是 平时 我 们 在 书写 时 不 写 而 已 。 另 外 ，DNS 域 名 不 仅 应 用 于 
Web 网 站 标识 ， 而 且 应 用 于 FTP 站 点 和 电子 邮件 系统 ， 只 不 过 具体 使 用 
时 前 面 所 指定 的 协议 或 格式 是 不 一 样 的 : Web 网 站 使 用 的 是 HTTP 
(http://www.itct.com.cn) ，FTP 站 点 使 用 的 是 FTP (如 


ftp://www.itct.com.cn) ， 电 子 邮 箱 地 址 格式 是 “邮箱 用 户 账户 名 @ 邮 箱 
DNS 域 名 ” (如 winda@itct.com.cn) 。 


从 以 上 介绍 可 以 看 出 ，DNS 名 称 是 由 两 大 部 分 组 成 的 ， 最 前 面 的 
部 分 代表 的 是 服务 器 的 本 地 计算 机 名 称 ， 后 面 全 部 是 对 应 服务 器 所 在 
域 的 域名 ， 而 且 这 两 部 分 中 间 是 以 小 圆 点 (.) 分 隔 、 连 接 的 ， 即 “本 
地 计算 机 和 名 .DNS 域名 ”。 这 就 是 为 什么 说 DNS 是 基于 域 命名 方案 的 原 
o 


DNS 域名 不 是 单一 结构 ， 而 是 包含 至 少 两 个 层次 的 分 级 结构 ， 因 
为 单一 结构 的 域名 无 法 满足 全 球 如 此 多 互联 网 用 户 的 需求 ， 驶 像 尽 管 
没有 限制 姓名 长 度 ， 而 且 汉字 有 上 万 个 ， 但 还 是 很 难 避 免 完 全 不 重 
名 。 如 果真 有 制度 限制 不 能 重 名 的 话 ， 则 后 面 出 生 的 人 名 字 可 能 都 非 
党 难 记 ， 或 者 都 是 他 们 目 己 不 喜欢 的 了 。DNS 域 名 也 一 样 ， 如 采 只 
一 级 结构 ， 则 后 面 用 户 所 能 申请 的 域名 基本 上 都 会 很 长 ， 且 不 能 符合 
用 户 特征 要 求 。 


在 分 层 结 构 的 DNS 域 名 中 ， 必 须 有 一 个 是 顶级 域名 ， 然 后 在 这 个 
顶级 域名 下 面 再 申请 ， 或 者 注册 二 级 、 三 级 ， 甚 至 更 多 级 别 的 域名 ， 
各 级 域名 间 同 样 是 以 小 圆 点 (.) 分 隔 、 连 接 的 。 最 右边 的 部 分 代表 的 
征 顶 级 域名 ， 左 边 部 分 代表 的 是 子 域名 ， 而 且 是 级 别 最 低 的 域名 写 在 
最 前 面 ， 级 别 最 高 的 域名 写 在 最 后 面 。 下 级 域名 必须 隶属 于 上 级 域 
和 名。 例如 ，itcticom.cn 这 个 DNS 域名 是 一 个 三 级 域名 ， 其 中 itct 征 三 级 


域名 (在 本 域名 中 级 别 最 低 ) ， 它 隶属 于 其 二 级 域名 com， 而 二 级 域 
名 com 又 隶属 于 其 一 级 域名 ( 义 称 顶级 域名 ) cn。 在 每 个 级 别 域名 
下 ， 又 可 以 有 多 个 并 列 关 系 的 下 级 域名 ， 如 顶级 域名 cn 下 面 可 以 有 
com、net、gov、edu 等 二 级 域名 ， 而 在 net 这 样 的 二 级 域名 下 面 同样 可 
以 有 由 各 用 户 申 请 注册 的 三 级 域名 。 


设计 这 样 的 分 层 结构 域名 的 好 处 很 明显 ， 就 是 上 级 域名 下 面 可 以 
有 多 个 不 同 的 下 级 域名 ， 且 整个 DNS 域名 中 只 要 有 一 级 域名 不 一 样 ， 
束 可 认为 该 域名 与 其 他 域名 是 不 一 样 的 。 这 样 束 可 以 比较 好 地 确保 互 
联网 上 域名 的 唯一 性 。 例 如 ，mov.microsoft.com 和 mail.microsoft.com 
这 两 个 域名 就 是 不 同 的 域名 ，sina.com.cn 和 sina.com 也 是 两 个 不 同 的 域 
名 o 

2. 解 析 性 能 不 足 的 解决 方案 

在 早期 利用 host 文 件 保存 计算 机 名 到 耳 地 址 映射 的 解决 方案 中 ， 
网 络 中 的 名 称 解 析 工 作 全 是 由 少数 几 个 集中 存储 host 文 件 的 服务 器 主 


机 来 担当 的 。 随 着 网 络 规模 的 不 断 扩大 ， 这 种 完全 集中 的 管理 方式 显 
然 不 能 满足 解析 性 能 要 求 ， 在 今天 的 互联 网 上 更 是 不 可 能 实现 。 


有 了 DNS 的 分 层 命 名 方案 后 ， 就 可 以 在 host 文 件 集 中 管理 的 基础 
上 进一步 采取 分 布 式 的 管理 方式 。 也 就 是 说 ， 可 以 针对 每 一 级 域名 用 
少数 的 DNS 服 务 句 单独 进行 名 称 解析 ， 这 样 一 来 ， 各 DNS 服 务 紫 的 解 


析 压 力 葡 不 会 变 得 难以 承受 了 。 例 如 ， 在 DNS 名 称 www.microsoft.com 
中 ， 顶 级 域名 com 是 由 对 应 的 顶级 域名 提供 两 的 DNS 服 务 器 人 负责 解析 
的 ， 二 级 域名 microsoft 是 由 对 应 的 二 级 域名 提供 两 的 DNS 服 务 右 负责 
解析 的 。 


目前 ， 整 个 互联 网 上 可 以 注册 的 域名 非常 多 ， 而 且 每 一 类 域名 义 
可 以 有 许多 域名 提供 商 提供 ， 这 样 一 来 ， 即 使 是 同一 类 域名 ， 在 全 球 
范围 内 都 可 以 有 非常 多 分 布 在 全 球 不 同 国家 或 地 区 的 域名 提供 商 的 
DNS 服务 器 来 共同 担当 名 称 解析 服务 ， 不 会 存在 性 能 不 足 的 问题 。 但 
要 特别 说 明 的 一 点 是 ， 这 些 DNS 服务 郁 都 不 是 孤立 的 ， 即 使 是 完全 不 
同 的 域名 解析 服务 右 ， 它 们 之 间 都 有 依次 的 从 属 关 系 ， 这 与 域名 提供 
商 的 级 别 有 关 。 下 级 域名 提供 商 的 DNS 服务 器 必须 与 上 级 域名 提供 商 
的 DNS 服 务 器 建立 某 种 关联 ， 否 则 可 能 同一 域名 会 在 不 同 地 区 被 多 人 
注册 ， 这 是 不 允许 的 。 


11.3.3 “DNS 名 称 空间 


从 大 的 范围 上 讲 ， 整 个 互联 网 是 一 个 DNS 名 称 空 间 ， 这 个 空间 是 
由 当时 可 以 注册 的 各 级 域名 共同 构成 的 。 当 然 ， 这 个 空间 会 随 着 用 户 
的 需求 和 互联 网 域名 管理 机 构 (ICANN 或 NeuLevel) 颁布 的 可 注册 域 
名 数量 和 类 型 的 扩展 而 扩展 。 整 个 DNS 名 称 空间 像 一 棵 倒 过 来 的 树 
(如 图 11-7 所 示 ) ， 最 顶端 称 为 互联 网 的 “ 根 域 "， 以 一 个 小 圆 点 (.) 
表示 ， 接 下 来 是 顶级 域 ， 再 接 下 来 是 二 级 域 、 三 级 域 ， 依 此 类 推 (一 
般 是 三 级 结构 。 注 意 ， 域 名 是 不 区 分 大 小 写 的 ， 但 通常 是 小 写 的 ) 。 
其 中 ， 顶 级 域名 和 二 级 域名 必须 是 由 对 应 的 互联 网 域名 管理 机 构 颁布 
的 。 


Se .国家 或 地 区 项 级 域 _ 入 二 x 通用 顶级 域 PP, `、、 ee 


ComD … CD 1 {CHD … Cm 
.| 类 别 二 级 域 ...- ”“、、 行政 区 域 二 级 域 


图 11-7 互联 网 上 的 DNS 名 称 空 间 


目前 ， 互 联网 上 注册 的 DNS 域名 主要 有 以 下 3 个 级 别 : 顶级 域名 、 
二 级 域名 和 三 级 域名 ， 其 中 只 有 二 级 及 其 以 下 级 别 的 域名 才 可 由 用 户 
目 己 申请 ， 用 户 不 能 直接 申请 顶级 域名 。 


1. 顶 级 域名 


顶级 域名 是 根 域名 (.) 下 面 的 第 一 级 域名 ， 但 它 不 能 单独 为 用 户 
分 配 。 目 前 顶级 域名 有 三 大 类 : 第 一 类 是 国家 或 地 区 类 ， 第 二 类 是 通 
用 类 ， 第 三 类 是 近期 新 增 的 通用 类 。 国 家 或 地 区 类 顶级 域名 是 为 每 个 
国家 或 地 区 分 配 的 域名 ， 由 ISO3166 进 行规 定 ， 如 cn 代表 中 国 ，us 代 表 
美国 ，jp 代 表 日 本 ..….... 


通用 类 顶级 域名 在 RFC1591 中 进行 规定 ， 如 商业 类 为 com、 教 育 类 
为 edu、 政府 类 为 gov、 国 际 组 织 类 为 int、 网 络 供应 商 类 为 net、 非 稻 利 
性 组 织 类 为 org.…... 近 期 新 增 的 通用 类 顶级 域名 有 biz (商业 组 织 ) 、 
film (公司 企业 ) 、store (商店 )、web (突出 WWW 活 动 的 组 织 ) 、 
arts (突出 文化 、 娱 乐 活动 的 组 织 ) 、rec (突出 消 遗 、 娱 乐 活动 的 组 
织 ) 、info (提供 信息 服务 的 组 织 ) 、.nom (个 人 ) 。 其 中 ，biz 顶 级 域 
名 是 为 了 接替 com 域 名 的 ， 因 为 com 域 名 空间 已 消耗 得 差不多 了 ， 但 它 
不 再 是 由 ICANN 管 理 ， 而 是 由 NeuLevel 公 司 单独 管理 。 


2. 二 级 域名 


二 级 域名 十指 顶级 域名 之 下 的 域名 。 它 又 分 为 两 大 类 : 在 国际 项 
级 域名 下 ， 它 是 指 域名 注册 人 的 网 上 名 称 ， 例 如 ibm、yahoo、microsoft 
等 ， 这 是 可 供用 户 申请 的 ， 在 国家 或 地 区 顶级 域名 下 ， 它 表示 注册 企 
业 类 别 的 符号 ， 如 com、edu、gov、net 等 ， 这 些 是 不 能 直接 供用 户 申 
请 注册 的 。 我 国 在 国际 互联 网 络 信 息 中 心 (Inter NIC) 正式 注册 并 运行 
的 顶级 域名 是 cn， 这 也 是 我 国 的 一 级 域名 。 目 前 ， 我 国有 中 文 域名 ， 

其 中 一 级 域名 为 “中 国 ”。 


在 顶级 域名 之 下 ， 我 国 的 二 级 域名 又 分 为 类 别 域名 和 行政 区 域名 
两 类。 类 别 域名 共 6 个 ， 包 括 用 于 科研 机 构 的 ac、 用 于 工商 金融 企业 的 
com、 用 于 教育 机 构 的 edu、 用 于 政府 部 门 的 gov、 用 于 互联 网 络 信息 中 
心 和 运行 中 心 的 net、 用 于 非 僵 利 组 织 的 org。 行政 区 域名 有 34 个 。 


3. 三 级 域名 


三 级 域名 也 是 可 以 由 用 户 自己 申请 注册 的 ， 可 以 采用 字母 (A~Z、 
a~z、 大 小 写 组 合 等 ) 、 数 字 (0~9) 和 连接 符 (-) 等 ， 各 级 域名 之 间 
用 小 圆 点 〈.) 连接 ， 三 级 域名 的 长 度 不 能 超过 20 个 字符 。 如 无 特殊 原 
因 ， 建 议 采用 申请 人 的 英文 名 (或 者 缩写 ) 或 者 汉语 拼音 名 (或 者 缩 
写 ) 作为 三 级 域名 ， 以 保持 域名 的 清晰 性 和 简洁 性 。 


一 般 来 说 ， 企 业 的 互联 网 域名 有 三 级 就 可 以 了 ， 如 果 还 需要 扩 
展 ， 可 以 继续 申请 更 多 级 别 的 域名 。 三 级 及 其 以 下 级 别 的 域名 是 可 以 


目 己 申请 注册 的 ， 只 要 在 其 上 一 级 域名 下 没有 重复 的 域名 即 可 。 另 
外 ， 以 上 是 针对 整个 互联 网 DNS 域 名 来 说 的 ， 其 实 和 针对 具体 的 公司 互 
联网 DNS 域 名 ， 同 样 有 一 个 名 称 空 间 ， 那 束 是 由 所 申请 的 顶级 域名 下 
扩展 的 各 级 域名 共同 构成 的 名 称 范围 (如 图 11-8 所 示 的 十 “新 浪 中 国 ”的 
一 部 分 DNS 名 称 空间 示例 ) ， 其 中 至 少 包 括 了 五 级 域名 ， 当 然 ， 要 能 
在 互联 网 供用 户 访问 ， 各 级 域名 也 都 必须 辐 互 联网 域名 管理 机 构 申 
请 、 注 册 。 


一 级 域名 


二 级 域名 


三 级 域名 


Chog Can 人 en GE 四 级 域名 


LS 


图 11-8 ”新浪 中 国 的 部 分 域名 空间 


五 级 域名 


经 验 之 谈 申请 的 DNS 域 名 是 不 包括 NetBIOS 计 算 机 名 部 分 的 ， 如 
microsoft.com 是 微软 公司 所 申请 的 一 个 二 级 域名 。 在 这 个 域名 下 ， 可 以 
有 许多 不 同 用 途 的 主机 ， 如 Web 服 务 器 、FTP 服 务 器 、E-mail 服 务 器 
等 ， 而 且 它 们 都 可 以 有 多 个 同类 服务 器 。 这 时 ， 像 


www.microsoft.com 、ftp.microsoft.com、 mail.microsoft.com 之 类 的 DNS 
名 称 中 的 www、ftp、mail 是 服务 器 的 NetBIOS 计 算 机 名 ， 不 包括 在 DNS 
域名 之 内 。 因 此 ， 以 上 DNS 名 称 都 属于 二 级 域名 ， 而 不 是 三 级 域名 ， 
当然 ， 如 果 确 实 申请 了 像 www、ftp、mail 之 类 的 三 级 域名 ， 则 男 当 别 
论 。 无 论 如 何 ， 在 浏览 器 中 输入 的 服务 器 地 址 中 最 左边 部 分 肯定 只 是 
该 服务 器 的 NetBIOS 计 算 机 名 ， 而 不 是 属于 DNS 域 名 。 


11.3.4 DNS 名 称 服务 器 


前 面 介 绍 的 DNS 系统 仅 是 从 服务 器 命名 角度 来 讲 的 一 项 技术 ， 但 
真正 担当 DNS 域名 解析 任务 的 还 生 那些 配置 了 DNS 服务 的 服务 夯 ， 融 
是 DNS 服务 器 ， 专 业 名 称 为 “名 称 服务 器 ”或 者 “域名 服务 器 ”) 。 在 
DNS 名 称 服 务 夯 中 ， 要 特别 注重 两 个 方面 : 一 是 DNS 服务 做 的 分 区 管 
理 ， 二 是 DNS 服 务 右 的 不 同类 型 以 及 它们 之 间 的 关系 。 


1.DNS 名 称 服务 器 的 分 区 管理 


从 理论 上 来 说 ， 每 一 级 的 每 个 DNS 域名 都 需要 配备 一 台 专 门 用 于 
名 称 解析 的 DNS 名 称 服 务 器 ， 但 古 全 球 有 那么 多 域名 ， 每 个 域名 都 专 
门 配备 的 话 ， 则 互联 网 域名 管理 机 构 所 需 配 备 的 DNS 名 称 服 务 右 就 实 
在 太 多 了 ， 这 明显 不 是 一 种 有 效 的 解决 方案 。 


为 了 提高 每 台 DNS 名 称 服务 器 的 运行 效率 和 利用 率 ， 在 DNS 技术 
中 为 此 专门 提出 了 “区 域 ”(zone) 的 概念 ， 就 是 可 以 让 一 台 或 多 台 DNS 
名 称 服 务 器 负责 一 个 区 域 的 计算 机 域名 解析 ， 而 这 个 “区 域 * 可 以 包括 
一 个 DNS 域 名 树 (或 者 说 “DNS 域 名 空间 ”) 的 一 部 分 (通常 是 包括 多 
级 域名 ) 或 全 部 ， 但 是 绝对 不 可 能 大 于 一 个 域名 树 ， 也 就 是 不 能 把 几 
个 完全 不 同 的 域 配置 为 一 个 区 域 ， 如 不 能 把 gz.lycb.com 和 sh.lycb.net 划 | 
分 为 一 个 DNS 区 域 。DNS 区 域名 是 对 应 区 域 中 公共 的 域名 树 部 分 ， 在 


如 图 11-9 所 示 的 示例 中 ， 假 设 只 划分 一 个 区 域 ， 则 这 个 区 域名 只 能 
lycb.com， 因 为 这 才 是 整个 区 域 中 的 公共 部 分 。 


服务 紫 主 机 名 


图 11-9 DNS 名 称 服务 器 分 区 示例 


在 如 图 11-9 所 示 的 DNS 域 名 树 示 例 中 ， 如 果 为 每 一 级 的 每 个 域名 分 
别 配 置 一 个 DNS 名 称 服 务 器 ， 那 么 这 样 一 个 简单 的 域名 树 就 需要 8 台 
DNS 名 称 服 务 器 ， 这 显然 是 不 合算 的 ， 也 是 没 必要 的 。 事 实 上， 如果 
这 个 域 网 络 中 的 应 用 服务 器 不 是 很 多 的 话 ， 整 个 此 DNS 域 就 只 划分 一 
个 区 域 (ycb.com) ， 仅 用 一 台 或 多 台 DNS 服 务 器 负责 名 称 解析 工作 ; 
如 果 各 级 域名 中 的 应 用 服务 器 数 比 较 多 ， 则 可 以 将 整个 DNS 域名 树 分 
成 如 图 11-9 所 示 的 3 个 区 域 ， 区 域名 分 别 为 jycb.com、sh.lycb.com 和 


gz.lycb.com， 然 后 为 这 3 个 区 域 各 配置 一 台 或 多 台 DNS 名 称 服务 右 即 
可 。 这 就 是 DNS 名 称 服务 右 的 分 区 理念 。 


至 于 具体 要 把 哪儿 级 域名 划分 在 同一 个 区 域 ， 这 个 不 是 固定 的 ， 
可 由 管理 员 来 决定 ， 但 一 般 取 决 于 各 级 域名 中 应 用 服务 郁 的 数量 ， 以 
及 这 些 服务 右 的 物理 位 置 。 通 稼 古 尽 可 能 使 各 区 域 中 应 用 服务 右 的 数 
量 均 衡 ， 以 便 使 各 区 域 中 的 DNS 名 称 服务 器 的 解析 负 三 尽 可 能 均衡 。 
同时 ， 还 应 尽 可 能 把 物理 位 置 相近 的 应 用 服务 紫 划 分 到 同一 个 区 域 
中 。 当 然 ， 越 高 一 级 别 区 域 的 DNS 名 称 服 务 器 的 负担 就 越 重 ， 因 为 它 
同时 还 会 为 下 级 区 域 中 的 DNS 名 称 服务 亏 提 供 解析 文 持 ， 即 在 下 级 区 
域 中 的 DNS 名 称 服务 器 解析 不 了 或 者 满 负荷 时 提供 帮助 。 


2.DNS 名 称 服 务 器 种 类 


为 了 有 效 地 管理 整个 互联 网 的 DNS 域 名 解析 工作 ，DNS 系 统 开发 
者 设计 了 一 个 与 分 层 的 DNS 域名 结构 类 似 的 层次 化 DNS 名 称 服 务 器 结 
构 ， 把 所 有 DNS 名 称 服务 器 自 高 到 低 分 成 4 个 级 别 : 根 名 称 服务 器 、 顶 
级 名 称 服务 器 、 权 威名 称 服务 器 和 本 地 名 称 服务 器 。 它 们 都 是 由 互联 
网 域名 管理 机 构 或 下 级 的 ISP 负 责 配 置 建立 的 ， 但 它们 都 不 是 由 一 台 服 
务 器 担当 ， 即 使 是 一 个 具体 的 域名 服务 器 也 都 有 一 台 主 服务 器 和 多 人 台 
辅助 服务 器 ， 就 像 在 配置 Windows Server 2003 DNS 服务 器 时 要 配置 一 
台 主 DNS 服务 器 、 一 台 或 多 台 辅 助 DNS 服务 器 一 样 。 下 面 分 别 介绍 这 
几 种 名 称 服 务 器 。 


(1) 根 名 称 服 务 器 


“ 根 名 称 服务 器 ” (root name server) 是 由 互联 网 管理 机 构 配 置 建立 
的 ， 是 最 高 层次 的 名 称 服务 器 ， 负 责 对 互联 网 上 所 有 “顶级 名 称 服务 
器 ”进行 管理 ， 有 全 部 的 顶级 名 称 服务 器 的 IP 地 址 和 域名 映射 。 


全 球 共 有 13 套 (注意 ， 不 是 13 台 ， 每 套 根 名 称 服务 响 都 有 好 多 人 台 
用 于 负载 均衡 的 根 名 称 服 务 器 ， 总 的 根 名 称 服 务 器 据说 至 少 有 上 千 人 台 
了 ) 根 名 称 服务 器 。 但 每 套 根 名 称 服 务 器 都 只 有 1 个 主根 名 称 服 务 器 

(也 就 是 说 ， 总 共 只 有 13 台 主根 名 称 服 务 器 ) ， 其 中 10 台 放置 在 美 

国 ， 两 台 在 欧洲 ，1 台 在 日 本 。 这 13 台 主根 名 称 服务 器 主机 名 分 别 为 字 
母 A~M， 即 完整 DNS 名 称 为 a.rootserver.net~m.rootserver.net， 具 体 如 表 
11-6 所 示 。 其 余 的 均 为 辅助 根 名 称 服 务 器 ， 分 布 在 世界 各 地 ， 其 日 的 是 
为 了 让 世界 各 地 都 能 就 近 获 取 根 名 称 服务 颖 的 解析 。 任 何 域名 解析 都 
要 经 过 这 13 公 根 名 称 服务 名 获得 顶级 名 称 服务 右 索 3 引 。 


表 11-6 13 台 主 根 名 称 服务 器 的 管理 机 构 和 IP 地址 


主根 名 称 服务 器 主机 名 管理 单位 及 设置 地 点 IP 地 址 
A INTERNIC.NET (美国 ， 弗 吉 尼 亚 州 ) 198.41.0.4 
B 美国 信息 科学 研究 所 (美国 ， 加 利 弗 尼 亚 州 》 128.9.0.107 
C PSINet 公司 〈 美 国 ， 弗 吉 尼 亚 州 ) 192.33.4.12 
D 马里兰 大 学 〈 美 国 马里 兰州 ) 128.8.10.90 
E 美国 航空 航天 管理 局 〈 美 国 加 利 弗 尼 亚 州 ) 192.203.230.10 
F 因特网 软件 联盟 (美国 加 利 弗 尼 亚 州 》 192.5.5.241 
G 美国 国防 部 网 络 信息 中 心 (美国 弗吉尼亚 州 192.112.36.4 
H 美国 陆军 研究 所 (美国 马里 兰州 ) 128.63.2.53 
I Autonomica 公司 (瑞典 ， 斯 德 哥 尔 摩 ) 192.36.148.17 
J VeriSign 公司 (美国 ， 弗 吉 尼 亚 州 ) 192.58.128.30 
K RIPE NCC (英国 ， 伦 敦 ) 193.0.14.129 
L IANA (美国 ， 弗 吉 尼 亚 州 ) 198.32.64.12 


其 实 ， 在 我 们 配置 Windows Server 2003 DNS 服务 器 的 “ 根 提示 ”时 
就 可 以 见 到 这 些 根 名 称 服 务 器 ， 如 图 11-10 所 示 ， 从 中 也 可 以 见 到 如 表 
11-6 所 示 的 这 些 主根 名 称 服务 器 的 IP 地 址 。 当 然 ， 如 果 配 置 的 是 局 域 网 
的 域名 ， 这 些 主根 名 称 服务 响 用 不 上 ， 因 为 这 些 主根 名 称 服 务 器 仅 用 
于 互联 网 上 的 域名 解析 。 
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事件 日 志 | 监视 | 安全 
接口 ”| 转发 器 | 高 级 根 提示 。 | ”调试 日 志 
根 提示 用 于 寻找 网 络 上 的 其 好 DNS 服务 器 。 
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d root-servers. net. [128. 8. 10. 90] 
e. root-servers. net. [192. 203. 230... 
f.root-servers. net. [192. 5. 5. 241] 
E. root-servers. net. [192. 112. 36. 4] 
h root-servers. net. [128. 63.2. 53] 
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职 消 ”| 应 用 | 


图 11-10 Windows Server 2003 DNS 服务 器 中 的 根 名 称 服 务 器 配置 对 
话 框 


注意 根 名 称 服 务 器 并 不 直接 用 于 名 称 解 析 ， 因 为 这 些 根 名 称 服 
务 器 上 也 没有 保存 全 部 的 互联 网 域名 记录 〈 仅 有 负责 管理 顶级 域名 的 
顶级 名 称 服务 器 的 相关 记录 ) 。 根 名 称 服务 器 的 作用 是 仅 当 用 户 本 地 
名 称 服务 器 解析 不 了 某 个 顶级 域名 时 ， 告 诉 本 地 名 称 服 务 絮 去 找 哪个 
顶级 名 称 服务 紫 。 


(2) 顶级 名 称 服 务 器 


“顶级 名 称 服 务 器 ” (top level name server) 是 各 顶级 域名 自己 的 名 
称 服 务 器 ， 负 责 它们 各 自 所 管理 的 二 级 域名 解析 。 每 一 个 顶级 域名 ， 
不 论 是 gTLD (通用 顶级 域 ' ， 还 是 ccTLD ( 国 别 顶级 域 ;' ， 它 们 都 有 
自己 的 域名 服务 器 。 如 顶级 域名 com 和 net 有 13 台 名 称 服 务 器 ， 主 机 名 
也 是 A~M， 域 名 为 gtld-servers.net; 顶级 域名 biz 有 6 台 名 称 服 务 器 ， 主 
机 名 是 A~H， 域 名 为 gtld.biz 。 


(3) 权威 名 称 服 务 器 


“权威 名 称 服 务 器 ” (authoritative name server) 是 针对 前 面 所 说 的 
DNS 区 域 提供 名 称 解 析 服 务 而 专门 配置 、 建 立 的 名 称 服 务 嚣 ， 可 为 用 
尸 提 供 最 权威 的 DNS 域 名 解析 。 每 一 个 域名 在 互联 网 上 都 可 找到 一 台 
权威 名 称 服 务 占 ，ISP 也 可 为 用 户 的 每 一 个 DNS 域 名 区 域 配 置 一 台 权 威 


名 称 服 务 器 。 


(4) 本 地 名 称 服 务 器 


这 里 所 说 的 “本 地 名 称 服 务 器 ”不 是 指 用 户 局 域 网 中 的 名 称 服 务 
器 ， 而 是 用 户 端 操作 系统 所 配置 的 、 由 本 地 ISP 提 供 的 名 称 服 务 器 (也 
就 是 本 地 DNS 服务 器 ) 。 它 是 离 用 户 最 近 的 互联 网 名 称 服 务 器 。 用 户 
发 出 的 DNS 域名 解析 请 求 ， 首 先 到 达 的 束 是 本 地 名 称 服 务 右 。 


11.3.5 DNS 报 文 格式 


与 HITP 报 文 一 样 ，DNS 报 文 也 分 为 请 求 报 文 和 应 答 报 文 两 类 ， 但 
DNS 的 请 求 报 文 和 应 答 报 文 的 总 体格 式 是 一 样 的 ， 只 是 一 些 参 数 的 取 
值 不 一 样 而 已 。DNS 报 文 也 分 为 两 部 分 ， 一 部 分 是 报关 部分， 为 一 部 
分 是 数据 部 分 。 报 头 部 分 是 固定 的 ， 有 6 个 字段 ， 共 12 字 节 大 小 ， 而 数 
据 部 分 由 四 大 部 分 组 成 ， 且 长 度 可 变 ， 如 图 11-11 所 示 。 下 面 主要 介绍 
DNS 报 头 部 分 以 及 数据 部 分 中 的 “查询 消息 ”和 “应 管 消息 ”等 内 容 。 


| 报头 部 分 
报头 ( header ) ( 共 12 字 节 ) 


查询 ( question ) 消息 


应 答 (answer ) 消息 数据 
部 分 
授权 (athority ) 应 答 


附加 (additional ) 信息 


图 11-11 DNS 报 文 基本 格式 


1. 报 头 部 分 


DNS 报头 部 分 的 格式 如 图 11-12 所 示 ， 下 面 是 各 字段 的 说 明 。 


ANcount 


ARcount 


图 11-12 DNS 报头 部 分 的 格式 


DID: 这 是 由 DNS 查询 程序 指定 的 16 位 请 求 标识 符 ， 每 次 查询 均 
会 分 配 一 个 标识 符 ， 相 当 于 查询 报 文 序 号 。 该 标识 符 也 会 被 随后 的 应 


答 报 文 所 用 ， 也 吏 是 应 答 报 文中 的 标识 符 与 其 对 应 的 请 求 报 文中 的 标 
识 符 是 一 样 的 ， 这 样 束 可 以 区 分 应 管 消 明 所 对 应 的 请 求 消 居 。 


口 QR: 报 文 类 型 标志 位 ， 占 1 位 ， 其 中 请 求 报 文 置 0， 应 答 报 文 置 


口 OPcode: 操作 码 标志 位 ， 用 于 设置 查询 的 种 类 ， 占 4 位 ， 应 答 的 
时 候 会 带 相同 值 。 置 0 时 表示 为 标准 查询 (QUERY) ; 置 1 时 表示 为 反 
向 查询 (IQUERY) ; 置 2 时 表示 为 服务 器 状态 查询 (STATUS) ; 其 他 
值 保 留 ， 暂 时 未 使 用 。 


DAA: 授权 应 答 (Authoritative Answer) 标志 位 ， 占 1 位 ， 仪 在 应 
答 报 文中 有 意义 。 置 1 时 表示 在 应 答 报 文中 所 给 出 的 名 称 服 务 器 是 所 查 
询 域 名 的 权威 名 称 服务 絮 。 


DTC: 截断 (TrunCation) 标志 位 ， 占 1 位 。 置 1 时 表示 该 报 文 超出 
最 大 报 文 长 度 ， 已 被 分 段 ， 置 O 时 表示 未 被 分 段 。 


DRD: 期 望 递 归 (Recursion Desired) 标志 位 ， 占 1 位 ， 在 请 求 报 
文中 设置 。 置 1 时 表示 建议 域名 服务 器 使 用 递归 查询 方法 ， 应 答 的 时 候 
使 用 相同 的 值 返 回 。 


DRA: 支持 递归 (Recursion Available) 标志 位 ， 占 1 位 ， 在 应 管 
报 文 中 设置 。 置 1 时 表示 名 称 服务 器 支持 递归 查询 ， 置 0 表示 不 支持 。 


后 面 紧 随 的 是 三 个 置 0 的 位 ， 用 于 保留 使 用 。 


口 Rcode: 应 管 码 (Response code) 标志 位 ， 占 4 位 ， 在 应 答 报 文 
中 设置 。 和 置 0 时 表示 无 错误 ， 置 1 时 表示 报 文 格式 有 和 错误， 名 称 服务 句 
不 接受 请 求 的 报 文 ， 置 2 时 表示 是 由 于 服务 器 的 原因 而 导致 无 法 处 理解 
析 请 求 ， 置 3 时 表示 解析 的 域名 不 存在 ;， 置 4 时 表示 名 称 服务 右 不 文 持 
所 请 求 的 查询 类 型 ， 置 5 时 表示 名 称 服务 右 由 于 设置 的 策略 而 拒绝 给 出 
应 答 。 例 如 ， 服 务 器 不 希望 对 某 些 请 求 者 给 出 应 答 ， 或 者 服务 器 不 希 
望 进行 某 些 操 作 (如 区 域 传 输 (zone transfer) ) 。 其 他 值 保留 ， 暂 时 
未 使 用 。 


口 QDcount: 16 位 整数 ， 表 示 在 报 文 后 面 “数据 ”部 分 “查询 消 居 ” 字 
段 中 的 问题 条 数 。 


口 ANcount: 16 位 整数 ， 表 示 在 报 文 后 面 “数据 ?部 分 "应答 消息 ? 字 
段 中 的 资源 记录 数 。 


DNScount，16 位 整数 ， 表 示 在 报 文 后 面 “数据 "部 分 “授权 应 答 ” 字 
段 中 的 名 称 服务 器 资源 记录 数 。 


口 ARcount: 16 位 人 整数， 表示 在 报 文 后 面 "数据 ?部 分 “附加 信息 ? 字 
段 中 的 资源 记录 数 。 


2. 请 求 消 轧 格式 


DNS 请 求 报 文中 的 具体 请 求 消 已 十 在 如 图 11-11 所 示 的 报 文 格式 
中 “查询 消息 ”部 分 显示 的 ， 包 括 对 应 DNS 域 名 查询 所 请 求 的 问题 。 
条 查询 消 居 的 格式 如 图 11-13 所 示 。 


图 11-13 查询 消息 格式 


1) QName: 表示 所 请 求解 析 的 域名 ， 不 过 它 显示 的 是 一 串 ASCII 
编码 ， 长 度 可 变 (注意 ， 不 是 固定 的 16 位 ) 。 在 每 个 域名 的 开头 以 及 
中 间 的 小 圆 点 (.) 部 分 均 为 一 个 十 六 进 制 数 ， 表 示 下 一 市 域名 的 ASCII 
字符 数 ， 后 面 是 每 节 域 名 各 个 符号 对 应 的 ASCII 字 符 (每 个 字母 和 符号 
均 占 1 字 市 ， 即 两 位 十 六 进 制 数字 ) ， 在 每 个 域名 的 最 后 均 以 一 个 字 节 
的 0 (00) 来 表示 。 但 要 注意 的 是 ， 这 个 字段 的 长 度 不 是 固定 的 ， 也 可 
以 为 奇数 个 字 节 ， 不 用 填充 。 


例如 ， 域 名 hi.baidu.com 在 请 求 消 恩 中 编码 为 02 68 69 05 62 61 69 
64 75 03 63 6F 6D 00， 其 中 “02” 表 示 它 的 下 一 廊 域名 中 包括 两 个 ASCII 


字符 ， 即 “hi”， 对 应 的 ASCII 字 符 为 68 69; “05” 表 示 它 的 下 一 节 域 名 中 
包括 5 个 ASCII 字 符 ， 即 “baidu”， 对 应 的 ASCII 字 符 为 62 61 69 64 
75; “03” 表 示 它 的 下 一 节 域 名 中 包括 3 个 ASCII 字 符 ， 即 “com”， 对 应 的 


ASCII 字 符 为 63 6F 6D; 最 后 的 “00” 表 示 该 域名 结束 。 


2) QType: 表示 查询 的 资源 记录 类 型 ， 占 2 字 节 ， 是 本 节 后 面 将 要 
介绍 的 资源 记录 中 的 TYPE 〈 类 型 ) 字段 的 扩展 。 表 11-7 中 的 TYPE 类 型 
字段 值 均 是 Qtype 字 段 合 法 的 取 值 《有 些 通用 的 QType 值 可 以 和 多 条 资 
源 记录 相 匹配 ) ， 另 外 ， 还 可 以 有 以 下 到 值 。 


口 AXFR: Authoritative Transfer (权威 转换 器 ) ， 值 为 252， 代 表 
完整 区 域 的 域名 解析 请 求 。 


DMAILB: Mail Box (邮箱 ) ， 值 为 253， 代 表 与 邮箱 相关 的 资源 
记录 ， 如 MB (邮箱 ) 、MG (邮件 组 ) 或 者 MR (邮箱 名 更 改 ) 记录 。 


DMAILA: Mail Agent (邮件 代理 ) ， 值 为 254， 代 表 邮 件 代 理 资 
源 记录 ， 如 目前 已 基本 不 用 的 MX (邮件 交换 ) 记录 。 


口 *， 值 为 255， 代 表 所 有 资源 记录 的 请 求 。 


3) QClass: 表示 查询 类 别 ， 占 2 字 节 ， 是 本 节 后 面 将 要 介绍 的 资 
源 记 录 中 的 CLASS (类 别 ) 字段 的 扩展 。 表 11-8 中 的 CLASS 字段 值 均 


是 QClass 字 段 合法 的 取 值 。 男 外 ， 新 增 了 一 个 “*” 查 询 类 别 ， 取 值 为 
255， 代表 所 有 分 类 * 


3. 资 源 记 录 格 式 


在 DNS 应 答 报 文中 ， 会 在 如 图 11-11 所 示 的 “应 管 消息 >、“ 授 权 应 
答 ” 和 “附加 信息 ”部 分 显示 所 应 答 的 资源 记录 信息 。 这 些 资源 记录 消息 
格式 是 一 样 的 ， 如 图 11-14 所 示 。 其 中 各 字段 说 明 如 下 。 


0 15 
NAME( 长 度 可 变 ) 
TE A 


TYPE 


CLASS 
RDLength 


RData (长 度 可 变 ) 


图 11-14 资源 记录 格式 


DNAME， 表示 资源 记录 对 应 的 域名 ， 与 DNS 请 求 报 文 QName 字 
段 所 请 求 域名 一 致 ， 该 字段 长 度 可 变 。 


DTTL: 表示 该 资源 记录 可 以 缓存 的 时 间 (以 秒 为 单位 ) ， 一 般 用 
于 当地 址 解析 程序 取出 资源 记录 后 决定 保存 及 使 用 缓存 数据 的 时 间 ， 
占 4 字 节 ， 置 0 时 表示 只 能 被 传输 ， 不 能 被 缓存 。 


DTYPE: 资源 记 杂 类 型 ， 占 2 字 刘 。 可 用 的 资源 记录 类 型 及 取 值 
说 明 如 表 11-7 所 示 。 这 里 仅 给 出 对 应 资源 记 杂 的 类 型 ， 并 不 是 具体 的 资 
源 记 了 录 内 容 ， 具 体 的 资源 记 杂 内 容 将 在 后 面 的 RData 子 段 中 介绍 。 


表 11-7 TYPE 值 类 型 及 取 值 说 明 

资源 记录 类 型 对 应 的 字段 值 说 明 

主机 记录 ， 给 出 一 个 主机 外 地址。 配置 了 多 个 IP 地 址 的 主机 有 对 应 数 
量 的 A 记录 

名 称 服务 器 记录 ， 给 出 一 个 权威 名 称 服务 器 IP 地 址 

邮件 目标 记录 ， 给 出 一 个 目的 邮件 地 址 。 已 过 时 ， 现 用 MX 记录 替代 

邮件 转发 器 记录 ， 给 出 一 个 邮件 转发 器 。 已 过 时 ， 现 用 MX 记录 替代 

规范 名 记录 ， 给 出 一 个 别名 的 规范 名 称 

起 始 授权 机 构 记录 ， 给 出 一 个 区 域 的 起 始 授权 机 构 名 称 服务 器 IP 地 址 

邮箱 记录 ， 给 出 一 个 邮箱 域名 。 仅 用 于 实验 

邮件 组 记录 ， 给 出 一 个 邮件 组 成 员 。 仅 用 于 实验 

邮件 更 名 记录 ， 给 出 一 个 邮件 重 命名 后 的 域名 。 仅 用 于 实验 

空 记录 ， 给 出 一 个 空 资源 记录 ， 相 当 于 换行 ， 主 要 是 为 了 增加 整个 资源 
记录 的 可 读 性 

熟知 服务 描述 记录 ， 给 出 一 个 熟知 服务 〈 像 HTTP、FTP、SMTP 这 类 
常规 服务 ) 的 描述 
PTR 12 指针 记录 ， 给 出 一 个 IP 地 址 的 别名 


中 
© 
> 


HINFO E 机 信息 记录 ， 给 出 主机 操作 系统 和 CPU 信息 

MINFO 邮箱 信息 记录 ， 给 出 一 个 邮箱 或 邮件 列表 信息 

i 邮件 交换 记录 ， 给 出 邮件 交换 的 优先 级 ， 以 及 希望 接受 该 域 电子 邮件 的 
E 机 

TXT 文本 记录 ， 一 个 文本 字符 串 


口 CLASS: 资源 记录 数据 的 类 别 ， 占 2 字 世 ， 可 用 的 数据 类 别 及 取 
值 说 明 如 表 11-8 所 示 ， 通 常 都 是 IN ( 即 Internet) 类 别 。 这 里 仅 给 出 对 

点 资源 记录 数据 〈 也 就 是 RData 字 段 中 的 内 容 ) 的 类 别 ， 并 不 是 具体 的 
资源 记录 内 容 ， 具 体 的 资源 记录 内 容 将 在 后 面 的 RData 字 段 中 介绍 。 


表 11-8 CLASS 值 类 别 及 取 值 说 明 
资源 记录 数据 类 别 说 明 
| “1 ”| 给 出 所 请 求解 析 域 名 对 应 的 IP 地 址 ， 是 默认 的 资源 记录 数据 类 别 
CSNET (Computer Science Network， 计 算 机 科学 网 络 ) 类别 ， 目 前 基本 不 用 
CH Chaos 类 别 ， 由 以 前 的 Symbolics Lisp 机 器 使 用 ， 已 经 被 废弃 


Hesiod 类 别 ， 用 来 查询 用 户主 目录 ， 现 在 也 不 用 了 


口 RDLength: 表示 RData (资源 数据 ) 字段 的 长 度 〈 以 字 节 为 单 


ft) 2 


口 RData:， 表示 具体 的 相关 资源 记录 ， 长 度 可 变 。 其 取 值 与 
TYPE、CLASS 字 上 段 值 有 关 。 例 如 ， 如 果 TYPE 值 为 A、CLASS 值 为 
IN， 那 么 RData 职 是 一 个 4 字 世 的 了 地 址 。 


11.3.6 ” DNS 数据 传输 方式 


DNS 服务 同样 也 是 C/S 工 作 模式 ， 分 为 DNS 服务 右 和 DNS 客户 端 。 
其 中 ，DNS 客 户 端 以 DNS 请 求 报 文 向 DNS 服务 器 发 出 域名 解析 请 求 ， 
DNS 服务 器 以 DNS 应 答 报 文 对 客户 端的 DNS 请 求 做 出 应 答 。 


DNS 既 可 以 报 文 方 式 通 过 TCP 53 号 端口 进行 报 文 分 组 传输 ， 也 可 
以 数据 报 方式 通过 UDP 53 号 端口 进行 数据 报 传输 。 至 于 何 时 使 用 
TCP、 何 时 使 用 UDP 进行 数据 传输 ， 需 要 从 以 下 几 个 方面 来 考虑 : 


口 当 DNS 数据 (包括 报头 和 数据 部 分 大 于 512 字 节 时 ， 只 能 采用 
TCP 进 行 数据 传输 ， 因 为 UDP 中 传输 的 数据 最 长 不 能 超过 512 字 节 。 至 
于 是 否 会 分 段 ， 取 决 于 具体 网 络 中 数据 链 路 层 的 MTU 值 。 如 果 被 分 
段 ， 则 在 DNS 报头 的 TC 标 志 位 置 1。 


口 在 区 域 传输 过 程 中 ， 也 天 是 在 从 主 DNS 服 务 右 问 辅助 DNS 服务 
器 传输 数据 时 必须 使 用 TCP， 因 为 这 样 传输 更 可 靠 。 


口 当 DNS 数据 小 于 512 字 节 时 (这 类 情况 比较 少 ) 是 使 用 TCP， 还 
和 是 UDP， 取 决 于 DNS 解析 右 ， 但 请 求 和 应 答 均 使 用 相同 的 协议 ， 不 会 
出 现 请 求 时 使 用 的 是 TCP， 而 在 应 答 时 使 用 的 是 UDP 的 情况 。 一 般 递 
归 解 析 时 使 用 UDP。 


DNS 域名 解析 其 实 很 多 是 查找 对 应 域名 权威 名 称 服 务 磊 ， 除 非 在 
本 地 名 称 服 务 器 绥 存 中 已 有 对 应 域名 的 记录 。 但 事实 上 ， 名 称 服务 器 
上 的 缓存 容量 和 可 以 缓存 的 时 间 都 有 限 ， 因 此 ， 绝 大 多 数 情况 下 是 需 
要 癌 权 威名 称 服 务 絮 来 求助 解析 的 。 


DNS 有 两 种 名 称 解 析 方 式 : 一 种 称 为 “递归 解析 ”(Recursive 
Solution，RS) ， 另 一 种 称 为 “迭代 解析 ” (Iterative Solution，IS) ,也 
称 “ 反 复 解 析 ”。 它 们 有 不 同 的 查询 和 应 答 流 程 ， 递归 解析 是 一 种 代理 
查询 方式 ， 如 果 本 地 名 称 服务 器 不 能 解析 ， 则 后 面 的 查询 请 求全 由 本 
地 名 称 服 务 器 代理 DNS 客户 端 进 行 查 询 ， 最 终 由 本 地 名 称 服 务 器 返回 
最 后 的 解析 结果 ;而 迭代 解析 中 的 查询 请 求全 由 DNS 客 户 端 自己 根据 
每 次 查询 从 上 级 DNS 服务 器 上 得 到 的 信息 依次 查询 下 级 DNS 服务 器 。 
这 就 好 比 你 要 找 一 家 你 从 未 去 过 的 公司 ， 如 果 是 通过 一 个 服务 公司 为 
你 去 查找 ， 然 后 把 结果 告诉 你 ， 这 融 相 当 于 递归 查询 ， 而 如 采 你 是 目 
己 一 步 步 去 找 人 问 ， 然 后 根据 每 次 问 话 得 到 的 信息 去 找 其 他 人 再 问 ， 
这 就 是 迭代 查询 。 下 面 将 分 别 介绍 这 两 种 名 称 解析 方式 。 


11.3.7 “DNS 递归 解析 原理 


“递归 解析 ” 《或 称 “ 递 归 查 询 "， 其 实意 思 是 一 样 的 ) 是 最 常见 的 默 
认 的 解析 方式 。 在 这 种 解析 方式 中 ， 如 有 果 客 户 闪 配置 的 本 地 名 称 服务 
如 不 能 解析 的 话 ， 则 后 面 的 查询 全 由 本 地 名 称 服 务 器 代 营 DNS 客户 闪 
进行 查询 ， 直 到 本 地 名 称 服务 右 从 权威 名 称 服 务 右 得 到 了 正确 的 解析 
结 琳 ， 然 后 由 本 地 名 称 服 务 占 告诉 DNS 客 户 端 查询 的 结 末 。 


1.DNS 冲 归 解 析 基 本 流程 


在 这 个 查询 过 程 中 ,一直 是 以 本 地 名 称 服务 器 为 中 心 的 ，DNS 客 
户 端 只 是 发 出 原始 的 域名 查询 请 求 报 文 ， 然 后 就 一 直 处 于 等 待 状态 ， 
直人 到 本 地 名 称 服务 右 发 来 了 最 终 的 三 询 结 采 。 此 时 的 本 地 名 称 服务 右 
束 相 当 于 中 介 代 理 的 作用 。 如 采 考 虑 了 本 地 名 称 服 务 郁 的 缓存 技术 
(也 就 是 在 DNS 服务 器 上 对 一 定数 量 的 以 前 查询 记录 保存 一 定时 间 ， 
这 样 后 面 查 询 同 样 的 域名 信息 时 束 可 直接 从 缓存 中 调 出 来 ， 以 加 速 碍 
询 效 率 ) 的 话 ， 则 递归 解析 的 基本 流程 如 下 。 


1) 客户 端 向 本 机 配置 的 本 地 名 称 服 务 器 《在 此 仅 以 首选 DNS 服务 
绥 为 例 进行 介绍 ， 所 配置 的 其 他 备用 DNS 服务 瑚 的 解析 流程 也 完全 一 
样 ) 发 出 DNS 域名 查询 请 求 。 


2) 本 地 名 称 服务 右 收 到 请 求 后 ， 先 查询 本 地 的 缓存 ， 如 果 有 该 域 
名 的 记录 项 ， 则 本 地 名 称 服务 融 直 接 把 碍 询 的 结 采 返回 给 客户 端 ; 如 
果 本 地 缓存 中 没有 该 域名 的 记 有 好， 则 本 地 名 称 服务 右 再 以 DNS 客 刻 站 
的 角色 发 送 与 前 面 一 样 的 DNS 域名 查询 请 求 给 根 名 称 服务 器 。 


3) 根 名 称 服务 器 收 到 DNS 请 求 后 ， 把 查询 到 的 所 请 求 的 DNS 域名 
中 顶级 域名 所 对 应 的 顶级 名 称 服 务 右 地 址 返回 给 本 地 名 称 服 务 紫 。 


4) 本 地 名 称 服务 器 根据 根 名 称 服务 器 返回 的 顶级 名 称 服务 器 地 
址 ， 向 对 应 的 顶级 名 称 服 务 右 发 送 与 前 面 一 样 的 DNS 域 名 查询 请 求 。 


5) 对 应 的 顶级 名 称 服务 器 在 收 到 DNS 查 询 请 求 后 ， 也 是 先 查 询 自 
己 的 缓存 ， 如 果 有 所 请 求 的 DNS 域名 的 记录 项 ， 则 先 把 对 应 的 记录 项 
退回 给 本 地 名 称 服 务 左 ， 人 然后 再 由 本 地 名 称 服务 融 返 回 给 DNS 客户 
端 ， 否 则 向 本 地 名 称 服 务 侨 返回 所 请 求 的 DNS 域 名 中 的 二 级 域名 所 对 
应 的 二 级 名 称 服务 右 地 址 。 


然后 ， 本 地 名 称 服务 絮 继 续 按 照 前 面 介绍 的 方法 一 次 次 地 问 三 
级 、 四 级 名 称 服务 器 查询 ， 直 到 最 终 的 对 应 域名 所 在 区 域 的 权威 名 称 
服务 器 运 回 最 终 的 记录 给 本 地 名 称 服务 上 囊 ， 再 由 本 地 名 称 服 务 器 返回 
给 DNS 客户， 同时 本 地 名 称 服 务 瑚 会 缓存 本 次 查询 得 到 的 记录 项 。 


2.DNS 递 归 解 析 示 例 


为 了 方便 读者 理解 ， 下 面 举例 进行 说 明 。 本 示例 中 假设 客户 端 想 
要 访问 自己 并 不 识别 的 example.microsoft.com 站 点 ， 并 假设 此 客户 端 配 
置 的 本 地 名 称 服 务 器 为 dns.company.com (通常 是 以 IP 地 址 方式 配置 
的 ) ， 本 地 名 称 服 务 器 上 配置 的 根 名 称 服务 器 是 a.rootserver.net。 整个 
递归 解析 过 程 如 图 11-15 所 示 (其 中 的 Q1~Q5 表 示 发 送 DNS 查 询 请 求 ， 


Al1~A5 是 DNS 查询 应 答 ) ， 有 具体 描述 如 下 。 


根 名 称 服务 器 


com 
DNS 客户 端 pon 顶级 名 称 服 务 器 
本 地 名 称 服务 器 


microsoft.com 


二 级 名 称 服务 器 


example.microsoft.com 


权威 名 称 服务 器 


图 11-15 DNS 递归 解析 示例 


1) DNS 客户 端 向 所 配置 的 本 地 名 称 服 务 器 dns.company.com 发 出 解 
析 example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 11-15 中 的 Q1) ， 相 


当 于 对 本 地 名 称 服务 妖 说 “请 给 我 example.microsoft.com 所 对 应 的 IP 地 
址 "。 


2) 本 地 名 称 服务 器 收 到 请 求 后 ， 先 查询 本 地 缓存 ， 如 果 没 有 查 到 
该 域名 的 对 应 记录 ， 则 本 地 名 称 服务 右 回 所 配置 的 根 名 称 服 务 右 
a.rootserver.net 发 出 解析 example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 
11-15 中 的 Q2) 。 


3) 根 名 称 服务 器 收 到 查询 请 求 后 ， 通 过 查询 得 到 .com 顶 级 域名 所 
对 应 的 顶级 名 称 服务 器 ， 然 后 向 本 地 名 称 服务 器 返回 一 条 应 答 报 文 
(图 11-15 中 的 A1) ， 相 当 于 说 “我 不 知道 example.microsoft.com 域 名 对 
应 的 IP 地 址 ， 但 我 现在 告诉 你 .com 域 名 对 应 的 顶级 名 称 服务 器 地 址 ”。 


4) 本 地 名 称 服 务 器 在 收 到 根 名 称 服务 器 的 DNS 应 答 报 文 ， 并 得 
到 .com 顶 级 域名 所 对 应 的 顶级 名 称 服务 器 地 址 后 ， 再 次 向 对 应 的 顶级 
名 称 服 务 器 发 送 一 条 请 求解 析 example.microsoft.com 域 名 的 DNS 请 求 报 
文 (图 11-15 中 的 Q3) 。 


5) .com 顶 级 名 称 服务 器 在 收 到 DNS 请 求 报 文 后 ， 先 查询 自己 的 组 
存 ， 假 设 也 没有 该 域名 的 记录 项 ， 则 查询 microsoft.com 对 应 的 二 级 名 称 
服务 器 ， 然 后 也 向 本 地 名 称 服务 右 返 回 一 条 DNS 应 答 报 文 (图 11-15 中 
的 A2) ， 相 当 于 说 “我 不 知道 example.microsoft.com 域 名 对 应 的 IP 地 
址 ， 但 我 现在 告诉 你 microsoft.com 域 名 对 应 的 二 级 名 称 服 务 器 地 址 ”。 


6) 本 地 名 称 服务 器 在 收 到 .com 顶 级 名 称 服务 器 的 DNS 应 答 报 文 ， 
并 得 到 microsoft.com 二 级 域名 所 对 应 的 二 级 名 称 服务 絮 地 址 后 ， 再 次 癌 
对 应 的 二 级 名 称 服 务 器 发 送 一 条 请 求解 析 example.microsoft.com 域 名 的 
DNS 请 求 报 文 (图 11-15 中 的 Q4) 。 


7) microsoft.com 二 级 名 称 服务 器 在 收 到 DNS 请 求 报 文 后 ， 也 先 碍 
询 目 己 的 缓存 ， 如 果 也 没有 该 域名 的 记录 项 ， 则 碍 询 
example.microsoft.com 对 应 的 权威 名 称 服务 器 (因为 这 个 名 称 服务 句 已 
包括 了 完整 域名 example.microsoft.com 所 在 区 域 ) ， 然 后 也 向 本 地 名 称 
服务 器 返回 一 条 DNS 应 答 报 文 (图 11-15 中 的 A3) ， 相 当 于 说 “我 不 知 
道 example.microsoft.com 域 名 对 应 的 IP 地 址 ， 但 我 现在 告诉 你 
example.microsoft.com 域 名 对 应 的 权威 名 称 服 务 絮 地址 ”。 


8) 本 地 名 称 服 务 器 在 收 到 microsoft.com 二 级 名 称 服务 器 的 DNS 应 
答 报 文 ， 并 得 到 example.microsoft.com 三 级 域名 对 应 的 权威 名 称 服务 器 
地 址 后 ， 再 次 向 对 应 的 权威 名 称 服 务 器 发 送 一 条 请 求解 析 
example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 11-15 中 的 Q5) 。 


9) 权威 名 称 服 务 器 在 收 到 DNS 请 求 后 ， 在 它 的 DNS 区 域 数 据 库 中 
查找 ， 最 终 会 得 出 example.microsoft.com 域 名 对 应 的 了 地 址 ， 然 后 向 本 
地 名 称 服务 器 返回 一 条 DNS 应 答 报 文 (图 11-15 中 的 A4) ， 相 当 于 


说 “example.microsoft.com 域 名 的 了 了 地 址 为 XXX.XXX.XXX.XXX”。 


10) 本 地 名 称 服 务 器 在 收 到 权威 名 称 服务 器 的 应 答 报 文 后 ， 向 
DNS 客户 端 返 回 一 条 DNS 应 答 报 文 〈 图 11-15 中 的 A5) ， 告 诉 DNS 客户 
端 example.microsoft.com 域 名 的 人 P 地 址 。 这 样 DNS 客 户 端 就 可 以 正常 访 
问 这 个 网 站 了 。 


如 果 在 步骤 9) 中 的 对 应 域名 的 权威 名 称 服务 器 中 都 找 不 到 对 应 的 
域名 记录 ， 则 会 向 本 地 名 称 服 务 器 返回 一 条 碍 询 失败 的 DNS 应 答 报 
文 ， 这 条 报 文 最 终 也 会 由 本 地 名 称 服务 器 返回 给 DNS 客户 端 。 当 然 ， 
如 果 这 个 权威 名 称 服务 器 上 配置 了 指向 其 他 名 称 服 务 器 的 转发 器 ， 则 
权威 名 称 服 务 器 还 会 在 转发 器 指向 的 名 称 服务 器 上 进一步 查询 。 

外 ， 如 果 DNS 客 户 端 上 配置 了 多 个 DNS 服务 器 ， 则 还 会 继续 向 其 他 
DNS 服务 圳 查询 。 


11.3.8 ”DNS 迭代 解析 原理 


在 上 面 介绍 的 DNS 递 归 解 析 中 ， 当 所 配置 的 本 地 名 称 服 务 絮 解析 
不 了 时 ， 后 面 的 查询 工作 是 由 本 地 名 称 服 务 占 蕉 代 DNS 客 户 端 进行 的 
(以 “本 地 名 称 服务 器 ”为 中 心 ) ， 只 需要 本 地 名 称 服 务 器 向 DNS 客户 
端 返 回 最 终 的 查询 结果 即 可 。 而 本 万 介绍 的 DNS 迭代 解析 〈 或 者 叫 “ 迭 
代 查 询 ”) 的 所 有 查询 工作 全 部 是 由 DNS 客户 端 目 己 完 成 的 〈 以 “DNS 
客户 端 " 自 己 为 中 心 ) 。 在 下 列 条 件 之 一 满足 时 就 会 采用 迭代 解析 方 
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口 在 查询 本 地 名 称 服务 器 时 ， 如 果 客 户 端的 请 求 报 文中 没有 申请 
使 用 递归 碍 询 ， 那 么 在 DNS 请 求 报 文 头 部 的 RD 字段 没有 置 1。 相 当 于 
说 , “你 都 没有 主动 要 求 我 为 你 进行 递归 查询 ， 我 当然 不 会 为 你 工作 
了 


口 客 户 端 在 DNS 请 求 报 文中 申请 使 用 的 是 递归 查询 (也 就 是 RD 子 
段 置 1 了 ) ,但 在 所 配置 的 本 地 名 称 服务 器 上 是 禁用 递归 查询 的 (DNS 
服务 器 一 般 默 认 支 持 递归 查询 ) ， 即 在 DNS 应 答 报 文 头 部 的 RA 字 段 置 
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1. 迄 代 解 析 的 基本 流程 


使 用 妈 代 解析 方式 时 ， 如 果 它 所 配置 的 主 名 称 服务 器 (如 Windows 
操作 系统 中 的 “首选 DNS 服务 器 ”) 不 能 解析 的 话 ， 那 么 客户 端 还 会 继 
续 向 所 配置 的 其 他 名 称 服 务 器 “如 Windows 操 作 系统 中 的 “备用 DNS 服 
务 器 ”) 查询 。 和 迭代 解 析 的 基本 流程 如 下 。 


1) 客户 端 向 本 机 配置 的 本 地 名 称 服 务 器 〈 在 此 仅 以 首选 DNS 服务 
器 为 例 进 行 介 绍 ， 其 他 备用 DNS 服务 器 的 解析 流程 也 完全 一 样 ) 发 出 
DNS 域名 查询 请 求 。 


2) 本 地 名 称 服务 器 收 到 请 求 后 ， 先 查询 本 地 的 缓存 ， 如 果 有 该 域 
名 的 记录 项 ， 则 本 地 名 称 服 务 器 直接 把 查询 的 结果 返回 给 客户 端 ， 如 
条 本 地 缓存 中 没有 该 域名 的 记录 ， 则 同 DNS 客户 端 返 回 一 条 DNS 应 答 
报 文 ， 报 文中 会 给 出 一 些 参考 信息 ， 如 本 地 名 称 服 务 吉 上 的 根 名 称 服 


务 絮 地 址 等 。 


3) DNS 客 户 端 在 收 到 本 地 名 称 服务 器 的 应 答 报 文 后 ， 会 根据 其 中 
的 根 名 称 服务 器 地 址 信息 ， 回 对 应 的 根 名 称 服 务 器 再 次 发 出 与 前 面 一 
样 的 DNS 查询 请 求 报 文 。 


4) 根 名 称 服 务 器 在 收 到 DNS 查 询 请 求 报 文 后 ， 通 过 查询 自己 的 
DNS 数据 库 得 到 请 求 DNS 域名 中 顶级 域名 所 对 应 的 顶级 名 称 服 务 邦 信 
已， 然后 以 一 条 DNS 应 答 报 文 返 回 给 DNS 客户 端 。 


5) DNS 和 客户 端 根据 来 目 根 名 称 服务 器 应 答 报 文中 的 对 应 顶级 名 称 
服务 旧地 址 信息 ， 同 该 项 级 名 称 服 务 右 发 出 与 前 面 一 样 的 DNS 人 查询 请 
求 报 文 。 


6) 顶级 名 称 服务 器 在 收 到 DNS 查 询 请 求 后 ， 先 查询 自己 的 缓存 ， 
如 东 有 所 请 求 的 DNS 域名 的 记录 项 ， 则 把 对 应 的 记录 项 返回 给 DNS 客 
户 端 ， 否 则 通过 得 询 后 把 对 应 域名 中 二 级 域名 所 对 应 的 二 级 名 称 服务 
妖 地 址 信息 以 一 条 DNS 应 管 报 文 返回 给 DNS 客 户 端 。 


然后 ，DNS 客 户 端 继 续 按照 前 面 介 绍 的 方法 一 次 次 地 加 三 级 、 四 
级 名 称 服 务 夯 查询 ， 直 到 最 终 的 权威 名 称 服 务 着 返回 最 终 的 记录 。 


2.DNS 迭 代 解 析 示 例 


为 了 方便 读者 理解 ， 举 例 说 明 。 本 示例 与 11.3.7 下 介绍 的 DNS 递归 
解析 一 样 ， 即 假设 客户 端 想 要 访问 目 己 并 不 识别 的 
example.microsoft.com 站 点 ， 并 假设 此 客户 问 配 置 的 本 地 名 称 服 务 右 为 
dns.company.com 〈 仅 以 一 个 本 地 名 称 服 务 器 为 例 进行 介绍 ) ， 在 该 本 
地 名 称 服 务 釉 上 配置 的 根 名 称 服 务 器 是 arootservernet。 整 个 迭代 解析 
过 程 如 图 11-16 所 示 (其 中 的 Q1~Q5 表 示 发 送 DNS 查 询 请 求 ，A1~A5 是 
DNS 和 查询 请 求 的 应 答 ) ， 具 体 描述 如 下 。 


根 名 称 服务 器 


本 地 名 称 
服务 器 


.COMm 


顶级 名 称 服务 器 


microsoft.com 


二 级 名 称 服务 器 


example.microsoft.com 


权威 名 称 服 务 器 


图 11-16 DNS 迭代 解析 示例 


1) DNS 客户 端 向 所 配置 的 本 地 名 称 服 务 器 dns.company.com 发 出 解 
析 example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 11-16 中 的 Q1) 。 


2) 本 地 名 称 服务 器 收 到 DNS 客户 端的 DNS 查询 请 求 报 文 后 ， 移 得 
询 本 地 缓存 。 如 有 果 没 有 查 到 该 域名 对 应 的 记录 ， 则 本 地 名 称 服务 器 把 
所 配置 的 根 名 称 服务 器 a.rootserver.net 地 址 信息 以 DNS 应 答 报 文 返回 给 
DNS 客 户 端 (图 11-16 中 的 A1) 。 


3) DNS 窗户 端 在 收 到 本 地 名 称 服 务 器 的 DNS 应 答 报 文 后 ， 根 据 其 
中 给 出 的 根 名 称 服务 盔 地 址 信息 ， 回 对 应 的 根 名 称 服务 硕 再 次 发 送 解 
析 example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 11-16 中 的 Q2) 。 


4) 根 名 称 服务 器 在 收 到 DNS 查询 请 求 后 ， 通 过 查询 得 到 .com 贾 级 
域名 对 应 的 顶级 名 称 服 务 器 ， 然 后 把 查询 到 的 对 应 顶级 域名 信息 以 一 
条 DNS 应 答 报 文 返回 给 DNS 客户 端 (图 11-16 中 的 A2) 。 


5) DNS 客户 端 在 收 到 根 名 称 服 务 器 的 DNS 应 答 报 文 ， 并 得 到 .com 
顶级 域名 对 应 的 顶级 名 称 服务 器 地 址 后 ， 再 次 癌 对 应 的 顶级 名 称 服务 
句 发 送 一 条 解析 example.microsoft.com 域 名 的 DNS 请 求 报 文 (图 11-16 中 
的 Q3) 。 


6) .com 顶 级 名 称 服 务 器 在 收 到 DNS 客户 端的 DNS 查询 请 求 报 文 

， 先 查询 自己 的 缓存 ， 假 设 也 没有 该 域名 的 记录 项 ， 则 查询 
microsoft.com 对 应 的 二 级 名 称 服 务 器 ， 然 后 把 查询 到 的 对 应 二 级 域名 信 
息 以 一 条 DNS 应 答 报 文 返回 给 DNS 客 户 端 (图 11-16 中 的 A3) 。 


7) DNS 客 户 端 在 收 到 .com 顶 级 名 称 服务 器 的 DNS 应 答 报 文 ， 并 得 
到 microsoft.com 二 级 域名 对 应 的 二 级 名 称 服务 器 地 址 后 ， 再 次 向 对 应 的 
二 级 名 称 服 务 器 发 送 一 条 解析 example.microsoft.com 域 名 的 DNS 请 求 报 
文 (图 11-16 中 的 Q4) 。 


8) microsoft,com 二 级 名 称 服 务 右 在 收 到 DNS 客户 端的 DNS 查询 请 
求 报 文 后 ， 也 先 查 询 自 己 的 缓存 ， 如 果 也 没有 该 域名 的 记录 项 ， 则 查 
询 example.microsoft.com 对 应 的 权威 名 称 服务 器 (因为 这 个 名 称 服务 句 

已 包括 了 整个 域名 example.microsoft.com 所 在 区 域 ) ， 然 后 把 查询 到 的 
对 应 权威 域名 信息 以 一 条 DNS 应 答 报 文 返 回 给 DNS 客户 端 (图 11-16 中 
的 A5) 。 


9) DNS 客户 端 在 收 到 microsoft.com 二 级 名 称 服务 器 的 DNS 应 答 报 
文 ， 并 得 到 example.microsoft.com 三 级 域名 对 应 的 权威 名 称 服务 器 地 址 
后 ， 再 次 向 对 应 的 权威 名 称 服 务 器 发 送 解 析 example.microsoft.com 域 名 
的 DNS 请 求 报 文 (图 11-16 中 的 Q5) 。 


10) 权威 名 称 服务 器 在 收 到 DNS 客户 端的 DNS 查询 请 求 报 文 后 ， 
在 它 的 DNS 区 域 数 据 库 中 查找 ， 最 终 会 得 出 example.microsoft.com 域 名 
对 应 的 JP 地址 ， 然 后 向 DNS 客 户 端 返 回 一 条 DNS 应 答 报 文 (图 11-16 中 
的 A5) 。 这 样 DNS 客 户 端 就 可 以 正常 访问 这 个 网 站 了 。 


如 果 在 步骤 10) 中 的 对 应 域名 的 权威 名 称 服 务 器 中 都 找 不 到 对 应 
的 域名 记录 ， 则 会 同 DNS 客 户 端 返 回 一 条 得 询 失 败 的 DNS 应 答 报 文 。 
当然 ， 如 末 这 个 权威 名 称 服 务 右 上 配置 了 指 回 其 他 名 称 服务 郝 的 转发 
二 ， 则 权威 名 称 服 务 夯 还 会 在 转发 套 指 辐 的 名 称 服务 左上 进一步 得 
询 。 另 外 ， 如 采 DNS 客 户 端 上 配置 了 多 个 DNS 服务 右 ， 则 还 会 继续 回 


其 他 DNS 服务 器 查询 。 


11.4 DHCP 服 务 


DHCP (动态 主机 配置 协议 ) 是 一 种 用 于 简化 主机 IP 配 置 管理 的 
服务 。 通 过 采用 DHCP 服 务 ， 可 以 使 用 DHCP 服 务 着 为 网 络 上 安装 了 
DHCP 服 务 客户 端 程序 的 客户 端 进 行动 态 IP 地 址 分 配 和 其 他 相关 设 
置 ， 而 不 需要 管理 员 对 各 个 客户 端 进行 一 一 配置 ， 城 办 了 许多 管理 负 
担 。 


11.4.1 BOOTP 和 DHCP 简 介 


DHCP 是 早期 BOOTP (Bootstrap Protocol， 自 举 协 议 ) 的 增强 版 
本 。BOOTP 是 一 个 基于 IP 和 UDP 的 协议 ， 最 早出 现在 UNIX 系 统 中 ， 
负责 UNIX 终 端的 远程 启动 ， 后 来 在 Windows 无 盘 网 络 中 也 得 到 广泛 使 
用 。 它 可 以 让 无 盘 站 点 从 一 个 中 心服 务 器 上 获得 JP 地 址 ， 为 局 域 网 中 
的 无 盘 站 点 分 配 动态 IP 地 址 ， 并 不 需要 每 个 用 户 去 设置 静态 IP 地 址 。 


在 使 用 BOOTP 时 ， 一 般 包括 “ 自 举 协议 服务 端 " 和 “ 自 举 协议 客户 
端 ” 两 部 分 。 在 为 无 盘 站 点 分 配 IP 地 址 时 ， 首 先 客 户 端 网 卡 会 以 0.0.0.0 
地 址 向 服务 器 发 出 耳 地 址 分 配 请 求 的 帧 ， 其 中 包括 站 点 网 卡 的 MAC 地 
址 。 BOOTP 服 务 器 在 接收 到 这 个 请 求 帧 后 ， 根 据 这 个 帧 中 的 MAC 地 
址 在 自己 的 自 举 数据 库 (BOOTP database) 中 查找 这 个 MAC 的 记录 ， 


如 果 没 有 此 MAC 的 记录 ， 则 不 会 应 答 这 个 请 求 ， 如果 有 ， 就 癌 站 点 返 
回 一 条 FOUND 帧 。FOUND 帧 中 包含 的 主要 信息 有 客户 端的 耳 地址、 
服务 器 的 IP 地 址 、 硬 件 类 型 、 网 关 IP 地 址 、 站 点 MAC 地 址 和 启动 映 象 
文件 名 。 站 点 根据 FOUND 帧 中 的 信息 获得 分 配 的 IP 地 址 信息 ， 然 后 通 
过 TFTP 服 务 癸 下 载 局 动 映 象 文件 ， 并 将 此 文件 在 站 点 内 存 模拟 成 磁 
盘 ， 从 这 个 模拟 磁盘 启动 。 


BOOTP 有 两 个 缺点 : 一 是 在 为 站 点 分 配 卫 地 址 前 ， 必 须 在 服务 器 
事先 配置 好 对 应 站 点 的 MAC 地 址 ， 管 理 员 的 工作 量 比较 大 (主要 是 体 
现在 事先 必须 收集 各 站 点 的 MAC 地 址 上 ) 。 二 是 BOOTP 分 配 的 IP 地 址 
是 静态 的 ， 没 有 租约 期 的 概念 ， 即 一 个 站 点 分 配 了 一 个 了 下地 址 后 ， 可 
以 永久 使 用 这 个 IP 地 址 ， 直 到 站 点 重启 或 关机 。 这 样 就 形成 了 一 个 一 
对 一 的 静态 关系 ， 不 利于 IP 地 址 的 有 效 使 用 。 


DHCP 不 但 是 BOOTP 的 增强 版 本 ， 而 且 是 基于 也 和 UDP 的 。DHCP 
全 面 弥 补 了 BOOTP 的 以 上 不 足 : 在 DHCP 服 务 铝 病根 本 不 用 配置 客户 
问 的 MAC 地 址 ， 这 样 也 束 无 须 管 理 员 去 收集 各 客户 端的 MAC 地 址 。 
另外 ，DHCP 通 过 利用 “租约 ”的 技术 可 以 大 大 提高 卫 地 址 的 使 用 效率 和 
安全 性 ， 不 再 是 一 对 一 的 静态 关系 ， 而 是 一 种 动态 分 配 关 系 。 同 时 ， 
在 功能 上 ，DHCP 相 对 BOOTP 有 全 面 的 增强 ， 通 过 DHCP 中 继 代理 功 
能 ， 一 个 DHCP 服 务 器 还 可 以 为 多 个 网 段 的 客户 端 目 动 分 配 卫 地 址 。 


DHCP 服 务 的 目的 是 通过 使 用 配置 了 DHCP 服 务 的 计算 机 或 网 络 设 
备 (如 三 层 交 换 机 、 路 由 器 ， 甚 至 防火 墙 ， 集中 管理 网 络 上 使 用 的 IP 
地 址 和 其 他 相关 配置 ， 从 而 降低 管理 地 址 配置 的 复杂 性 。 例 如 ， 在 
Windows 2000 Server/Windows Server 2003/Windows Server 2008 以 及 各 
种 Linux 和 UNIX 服 务 器 操作 系统 中 都 提供 了 DHCP 服 务 ， 同 时 ， 各 种 
三 层 交 换 机 、 路 由 器 “包括 视 带 路 由 器 ) 等 也 都 全 面 支持 了 DHCP 服 
务 。 注 意 ， 最 新 的 DHCP 草 案 标准 为 RFC 2131。 


DHCP 服 务 之 所 以 能 为 DHCP 客 户 端 目 动 分 配 IP 地 址 ， 其 根本 原 
是 在 DHCP 服 务 器 中 已 准备 好 了 用 来 为 客户 端 分 配 耳 地 址 的 耳 地 址 池 。 
这 个 IP 地 址 池 就 像 装 满 了 可 用 于 分 配 的 许多 了 PP 地址 的 池子 一 样 ， 而 且 
这 些 IP 地 址 是 属于 一 个 网 段 的 一 部 分 或 者 全 部 的 卫 地 址 。 有 关 DHCP 的 
IP 地 址 分 配 原理 将 在 本 章 后 续 部 分 介绍 。 


11.4.2 DHCP 上 服务 的 主要 功能 及 应 用 环境 

本 节 开 始 介绍 一 下 DHCP 服 务 的 主要 功能 、 使 用 DHCP 服 务 的 好 
处 ， 以 及 DHCP 服 务 的 主要 应 用 环境 。 

1.DHCP 服 务 的 主要 功能 


DHCP 服 务 不 仅 提 供 稍 单 的 下地 址 目 动 分 配 功能 ， 还 可 以 提供 以 
下 附加 功能 : 


口 通过 了 地 址 邱 MAC 地 址 绑 定 功能 实现 静态 IP 了 地址 的 分 配 。 


口 配 置 客户 端的 DNS 服务 器 、WINS 服 务 器 ( 仅 限 Windows 操 作 系 
统 中 的 DHCP 服 务 器 ) 和 默认 网 关 。 


口 利 用 IP 地 址 排除 功能 ， 使 已 静态 分 配给 其 他 主机 (特别 是 各 种 
服务 器 ) 的 了 地 址 不 再 分 配给 其 他 DHCP 客 户 端 。 


口 通 过 DHCP 中 继 功 能 ， 一 个 DHCP 服 务 器 可 以 为 多 个 网 段 (或 
VLAN) 中 的 DHCP 客 户 端 分 配 不 同 地 址 池 中 的 IP 地 址 ， 进 一 步 简化 了 
网 络 中 的 IP 地 址 配置 工作 。 


2. 使 用 DHCP 服 务 的 好 处 


在 管理 基于 TCP/IP 的 网 络 中 ， 使 用 DHCP 服 务 有 以 下 好 处 。 


(1) 减少 TcP/IP 配 置 和 管理 的 工作 量 


使 用 了 DHCP 服 务 后 ， 安 装 了 DHCP 客 户 端 程序 (现在 几乎 所 有 操 
作 系 统 都 目 带 并 安装 了 这 一 程序 ) 的 计算 机 可 直接 选择 如 图 11-17 所 示 
的 “自动 获得 耳 地 址 ”和 “自动 获得 DNS 服务 器 地 址 选项， 这 样 客户 端 
束 无 须 配 置 IP 地 址 、 子 网 掩 码 、 网 天 、DNS 服 务 如 地址 等 TCP/IP 信 
自 。 


dn 


Internet 协议 版 本 4 (T CP/IPv4) 尾 性 
宙 EL 
2 间 良 语 


g 自动 获得 IP 地 址 避 ) 


局 使 用 下 面 的 了 地 址 &): 


全 有 下 Mi 地上 


.DHS 最 务 去 起 


11-17 DHCP 选 项 配置 对 话 框 


由 此 可 见 ，DHCP 服 务 可 大 大 减轻 管理 员 的 工作 负担 (一 般 
TCP/PP 的 配置 是 需要 管理 员 权限 的 ) 。 注 意 ， 由 DHCP 服 务 器 目 动 分 
配 的 IP 地 址 都 有 一 个 租约 期 ， 也 就 是 目 分 配给 某 个 客户 端 开 始 ， 该 客 
户 端 只 能 在 这 个 租约 期 内 使 用 所 分 配 的 这 个 了 地 址 ， 但 过 期 后 可 以 续 
约 ， 或 者 重新 申请 。 


(2) 方便 客户 端 移动 


使 用 DHCP 服 务 上 自动 为 客户 端 分 配 IP 地 址 还 有 一 个 好 处 就 是 方便 
客户 端的 移动 ， 这 对 于 需要 移动 办 公 的 人 来 说 非常 实用 ， 这 样 客户 端 
连接 在 哪里 就 可 以 从 对 应 网 段 (或 VLAN) 配置 的 DHCP 服 务 器 上 自动 
分 配对 应 网 段 的 IP 地 址 。 反 过 来 ， 如 果 采 用 的 是 静态 IP 地 址 分 配方 
式 ， 则 客户 端 每 次 移动 到 一 个 其 他 网 段 (或 VLAN) ， 管 理 员 都 需要 
重新 设置 一 次 TCP/IP 信 息 。 


(3) 配置 更 加 可 靠 


采用 DHCP 服 务 目 动 分 配 了 地址 信息 可 以 有 效 地 避免 由 于 配置 时 
的 输入 错误 而 引起 的 配置 错误 ， 还 有 助 于 防止 在 网 络 上 配置 新 的 计算 
机 时 因 重 用 以 前 指派 的 IP 地 址 而 引起 的 地 址 冲突 。 


3.DHCP 服 务 的 主要 应 用 环境 


在 下 列 场合 ， 通 常 利 用 DHCP 服 务 来 完成 IP 地 址 的 分 配 。 


口 网 络 规模 较 大 ， 手 工 配 置 需 要 很 大 的 工作 量 ， 并 难以 对 整个 网 
络 进 行 集中 管理 。 当 然 ， 像 各 种 服务 右 、 网 络 设备 节点 都 是 需要 采用 
静态 了 地 址 分 配 的 ， 否 则 用 户 可 能 无 法 访问 你 的 服务 器 ， 网 络 设备 也 
无 法 进行 正 第 的 数据 转发 和 路 由 。 


口 网 络 中 主机 数目 大 于 该 网 络 文 持 的 IP 地 址 数量 ， 无 法 给 每 个 主 
机 分 配 一 个 固定 的 IP 地 址 。 例 如 ，Internet 接 入 服务 提供 商 限制 同时 接 
入 网 络 的 用 户 数 目 ， 大 量 用 户 必须 动态 获得 目 己 的 JP 地址 。 


口 网 络 中 只 有 少数 主机 需要 固定 的 IP 地 址 ， 大 多 数 主机 没有 固定 
的 IP 地 址 需求 。 


11.4.3 ”DHCP 报 文 及 其 格式 


DHCP 服 务 同样 工作 在 C/S (客户 端 /服务 器 ) 模式 中 ， 但 客户 端 与 
服务 器 进行 报 文 传输 时 使 用 的 UDP 传 输 端口 是 不 一 样 的 ，DHCP 客 户 端 
使 用 UDP 68 端 口 发 送 请 求 报 文 ，DHCP 服 务 器 使 用 UDP 67 端 口 发 送 应 
答 报 文 。DHCP 客 户 端 同 DHCP 服 务 右 发 送 的 报 文 称 为 DHCP 请 求 报 
文 ， 而 DHCP 服 务 右 同 DHCP 客 户 端 发 送 的 报 文 称 为 DHCP 应 答 报 文 。 


1.DHCP 报 文 类 型 


整个 DHCP 服 务 一 共有 8 种 类 型 (主要 是 前 面 7 种 类 型 ) 的 DHCP 报 
文 ， 分 别 为 DHCP DISCOVER、DHCP OFFER 、DHCP REQUEST、 
DHCP ACK ~ DHCP NAK ~ DHCP RELEASE ~ DHCP DECLINE 、 


DHCP INFORM 。 上 壕 报 文 类 型 的 介绍 如 表 11-9 所 示 。 


表 11-9 DHCP 报 文 类 型 


DHCP 报 文 类 型 说 明 
因为 DHCP 客户 端 在 请 求 IP 地 址 时 并 不 知道 DHCP 服务 器 的 位 置 ， 因 此 DHCP 客户 端 
会 在 本 地 网 络 内 以 广播 方式 发 送 DISCOVER 请 求 报 文 ， 以 发 现 网 络 中 的 DHCP 服务 器 。 
所 有 收 到 DISCOVER 报 文 的 DHCP 服务 器 都 会 发 送 应 答 报 文 ， DHCP 客户 端 据 此 可 以 知道 
网 络 中 在 在 的 DHCP 服务 器 的 位 置 
DHCP 服务 器 收 到 DISCOVER 报 文 后 ， 就 会 在 所 配置 的 地 址 池 中 查找 一 个 合适 的 IP 地 
址 ， 加 上 相应 的 租约 期 限 和 其 他 配置 信息 (如 网 关 、DNS 服务 器 等 )， 构 造 一 个 OFFER 报 
文 ， 发送 给 DHCP 客户 端 ， 告 知 用 户 本 服务 器 可 以 为 其 提供 IP 地 址 。 但 这 个 报 文 只 是 告诉 
DHCP 客户 端 可 以 提供 IP 地 址 ， 最 终 还 需要 客户 端 通过 ARP 来 检测 该 IP 地 址 是 否 重复 
因为 DHCP 客户 端 可 能 会 收 到 很 多 OFFER 请 求 报 文 ， 所 以 必须 在 这 些 应 答 中 选择 一 个 。 
通常 是 选择 第 一 个 OFFER 应 答 报 文 的 服务 器 作为 自己 的 目标 服务 器 ， 并 向 该 服务 器 发 送 
-个 广播 的 REQUEST 请 求 报 文 ， 通 告 选择 的 服务 器 ， 希 望 获得 所 分 配 的 IP 地址 。 另外， 
DHCP 客户 端 在 成 功 获取 IP 地 址 后 ， 在 地 址 使 用 租 期 过 去 12 时 ， 也 会 向 DHCP 服务 器 
发 送 单 播 REQUEST 请 求 报 文 以 请 求 续 延 租约 ， 如 果 没 有 收 到 ACK 报 文 ， 在 租 期 过 去 3/4 
时 ， 会 再 次 发 送 广播 的 REQUEST 请 求 报 文 以 请 求 续 延 租约 
当 DHCP 服务 器 收 到 REQUEST 请 求 报 文 后 ， 根 据 REQUEST 报 文 中 携带 的 用 户 MAC 
DHCP ACK 地 址 来 查找 有 没有 相应 的 租约 记录 ， 如 果 有 ， 则 发 送 ACK 应 答 报 文 ， 通 知 用 户 可 以 使 用 分 
配 的 IP 地 址 
如 果 DHCP 服务 器 收 到 REQUEST 请 求 报 文 后 ， 设 有 发 现 有 相应 的 租约 记录 或 者 由 于 其 
DHCP NAK 些 原因 无 法 正常 分 配 IP 地 址 ， 则 向 DHCP 客户 端 发 送 NAK 应 答 报 文 ， 通 知 用 户 无 法 分 配 
合适 的 IP 地 址 
当 DHCP 客户 端 不 再 需要 使 用 分 配 IP 地 址 时 ， 就 会 主动 向 DHCP 服务 器 发 送 RELEASE 
请 求 报 文 ， 告 知 服务 器 用 户 不 再 需要 分 配 IP 地 址 ， 请 求 DHCP 服务 器 释放 对 应 的 卫 地址 
DHCP 客户 端 收 到 DHCP 服务 器 ACK 应 答 报 文 后 ， 通 过 地 址 冲突 检测 机 制 发 现 服 务 器 
DHCP DECLINE 分 配 的 地 址 冲突 或 者 由 于 其 他 原因 导致 不 能 使 用 ， 则 会 向 DHCP 服务 器 发 送 DECLINE 请 
求 报 文 ， 通 知 服务 器 所 分 配 的 IP 地 址 不 可 用 ， 以 期 获得 新 的 IP 地 址 
DHCP 客户 端 如 果 需 要 从 DHCP 服务 器 端 获 取 更 为 详细 的 配置 信息 ， 则 向 DHCP 服务 器 
DHCP INFORM 发 送 INFORM 请 求 报 文 ， DHCP 服务 器 在 收 到 该 报 文 后 ， 将 根据 租约 进行 查找 ， 当 找到 相 
应 的 配置 信息 后 ， 向 DHCP 客户 端 发 送 ACK 应 答 报 文 。 注 意 ， 目 前 基本 上 不 用 了 


DHCP DISCOVER 


DHCP OFFER 


DHCP REQUEST 


DHCPRELEASE 


2.DHCP 报 文 格式 


虽然 DHCP 服 务 的 报 文 类 型 比较 多 ， 但 每 种 报 文 的 格式 基本 相同 ， 
只 是 某 些 字段 取 值 可 能 不 同 。DHCP 报 文 格式 基于 BOOTP 的 报 文 格 
式 ， 如 图 11-18 所 示 。 下 面 是 各 字段 的 说 明 ， 其 中 具体 取 值 参见 11.4.4 他 
给 出 的 示例 。 


0 7 15 23 31 位 


Chaddr ( 128 位 ) 


Sname ( $12 位 ) 


File (1024 位 ) 


Options( 可 变 长 ) 


图 11-18 DHCP 报 文 格式 


口 OP: Operation， 指 定 DHCP 报 文 的 操作 类 型 ， 占 8 位 。 请 求 报 文 
置 1， 应 答 报 文 置 2。 表 11-9 的 报 文 类 型 中 ，DHCP DISCOVER、DHCP 
REQUEST、DHCP RELEASE、DHCP INFORM 和 DHCP DECLINE 为 请 
求 报 文 ， 而 DHCP OFFER、DHCP ACK 和 DHCP NAK 为 应 答 报 文 。 


DHtype、Hlen: 分 别 指定 DHCP 客 户 端 的 MAC 地 址 类 型 及 长 度 ， 
各 占 8 位 。MAC 地 址 类 型 其 实 是 指明 网 络 类 型 ，Htype 字 段 置 1 时 表示 为 
最 常见 的 以 太 网 MAC 地 址 类 型 。 以 太 网 MAC 地 址 长 度 为 6 字 节 ， 即 对 
应 Hlen 字 段 值 为 6。 


DHops: DHCP 报 文 经 过 的 DHCP 中 继 的 数目 ， 占 8 位 。DHCP 请 求 
报 文 每 经 过 一 个 DHCP 中 继 ， 该 字段 融会 增加 1。 没 有 经 过 DHCP 中 继 时 
值 为 0。 


口 Xid: 客户 端 通过 DHCP DISCOVER 报 文 发 起 一 次 IP 地 址 请 求 时 
所 选择 的 随机 数 ， 相 当 于 请 求 标识 ， 占 32 位 。 用 来 标识 一 次 了 地 址 请 
求 过 程 。 在 一 次 请 求 中 所 有 报 文 的 Xid 都 是 一 样 的 。 


口 Secs: 表示 DHCP 客 户 并 从 获取 到 IP 地 址 或 者 续 约 过 程 开始 到 现 
在 所 消耗 的 时 间 ， 以 秒 为 单位 ， 占 16 位 。 在 没有 获得 IP 地 址 前 该 字段 
始终 为 0。 


口 Flags: 标志 位 ， 占 16 位 ， 第 一 位 为 广播 应 答 标 识 位 ， 用 来 标识 
DHCP 服 务 句 应 管 报 文 是 采用 单 播 还 是 广播 发 送 ， 置 0 时 表示 采用 单 揪 
发 送 方式 ， 置 1 时 表示 采用 广播 发 送 方式 。 其 余 位 傈 留 。 


注意 ”在 客户 端正 式 分 配 了 IP 地 址 之 前 的 第 一 次 IP 地 址 请 求 过 程 
中 ， 所 有 DHCP 报 文 都 是 以 广播 方式 发 送 的 ， 包 括 客户 端 发 送 的 DHCP 
DISCOVER 和 DHCP REQUEST 报 文 ， 以 及 DHCP 服 务 絮 发 送 的 DHCP 


OFFER、DHCP ACK 和 DHCP NAK 报 文 。 当 然 ， 如 果 是 由 DHCP 中 继 
妖 转 发 的 报 文 ， 则 都 是 以 单 播 方式 发 送 的 ， 具 体内 容 在 11.4.6 市 介绍 。 
男 外 ，IP 地 址 续 约 、IP 地 址 释放 的 相关 报 文 都 是 采用 单 播 方式 发 送 的 ， 
具体 内 容 在 11.4.5 节 介绍 。 


口 Ciaddr: 指示 DHCP 客 户 端 的 IP 地 址 ， 占 32 位 (4 字 节 ) 。 仅 在 
DHCP 服 务 器 发 送 的 ACK 报 文中 显示 ， 在 其 他 报 文中 均 显 示 0， 因 为 在 
得 到 DHCP 服 务 器 确认 前 ，DHCP 客 户 端 还 没有 分 配 到 IP 地 址 。 


DYiaddr 指示 DHCP 服 务 器 分 配给 客户 端的 IP 地 址 ， 占 32 位 (4 字 
节 ) 。 仅 在 DHCP 服 务 器 发 送 的 OFFER 和 ACK 报 文中 显示 ， 其 他 报 文 
中 显示 为 0。 


DSiaddr: 指示 下 一 个 为 DHCP 客 户 端 分 配 IP 地 址 等 信息 的 DHCP 服 
#IP 地 址 ， 占 32 位 (4 字 节 ) 。 仅 在 DHCP OFFER、DHCP ACK 报 文 


务 胡 
中 显示 ， 其 他 报 文中 显示 为 0。 


口 Giaddr: 指示 DHCP 客 户 端 发 出 请 求 报 文 后 经 过 的 第 一 个 DHCP 
中 继 的 IP 地 址 ， 占 32 位 (4 字 节 ) 。 如 果 没 有 经 过 DHCP 中 继 ， 则 显示 
为 0。 


口 Chaddr: 指示 DHCP 客 户 端 的 MAC 地 址 ， 占 128 位 (16 字 节 ) 
在 每 个 报 文中 都 会 显示 对 应 DHCP 客 户 端 的 MAC 地 址 。 


口 Sname: 指示 为 DHCP 客 户 端 分 配 IP 地 址 的 DHCP 服 务 右 名 称 
(DNS 域名 格式 ) ， 占 512 位 (64 字 节 ) 。 在 OFFER 和 ACK 报 文中 显示 
发 送 报 文 的 DHCP 服 务 器 名 称 ， 其 他 报 文 显 示 为 0。 


口 File: 指示 DHCP 服 务 器 为 DHCP 客 户 端 指定 的 启动 配置 文件 名 称 
及 路 径 信息 ， 占 1024 位 (128 字 节 ) 。 仅 在 DHCP OFFER 报 文中 显示 ， 
其 他 报 文 中 显示 为 空 。 


口 Options， 可 选项 字段 ， 长 度 可 变 。 


此 部 分 可 选 的 选项 包含 报 文 类 型 (代码 为 53， 占 1 字 节 ) 、 有 效 租 
约 期 (代码 为 51， 以 秒 为 单位 ， 占 4 字 节 ) 、 续 约 时 间 (代码 为 58， 占 
4 字 节 ) 、 子 网 掩 码 (代码 为 1， 占 4 字 节 ) 、 默 认 网 关 (代码 为 3， 可 
以 是 一 个 路 由 器 IP 地 址 列表 ， 长 度 可 变 ， 但 必须 是 4 字 节 的 倍数 ) 、 
DNS 服务 器 (代码 为 6， 可 以 是 一 个 DNS 服 务 器 IP 地 址 列表 ， 长 度 可 
变 ， 但 必须 是 4 字 市 的 整数 倍 ) 、 域 名 称 (代码 为 15， 主 DNS 服 务 器 名 
称 ， 长 度 可 变 ) 、WINS 服 务 器 〈 代 码 为 44， 可 以 是 一 个 WINS 服 务 器 
IP 列 表 ， 长 度 可 变 ， 但 必须 是 4 字 市 的 倍数 ) 等 配置 信息 。 表 11-19 所 示 
的 DHCP 报 文 类 型 的 取 值 分 别 如 下 。 


LIDHCP DISCOVER: 1 


LIDHCP OFFER: 2 


LIDHCP REQUEST: 3 


LIDHCP DECLINE: 4 


LIDHCP ACK: 5 


LIDHCP NAK: 6 


LIDHCP RELEASE: 7 


11.4.4 DHCP 服 务 的 卫 地 址 目 动 分 配 原 理 


DHCP 在 提供 服务 时 ，DHCP 客 户 端 是 通过 UDP 68 号 端口 进行 数 
据 传输 的 ， 而 DHCP 服 务 硕 则 是 以 UDP 67 号 端口 进行 数据 传输 的 。 
DHCP 服 务 不 仅 体 现在 为 DHCP 客 户 端 提供 IP 地 址 目 动 分 配 的 过 程 中 ， 
还 体现 在 后 面 的 IP 地 址 续 约 和 释放 过 程 中 。 本 节 仪 介绍 DHCP 客 户 端 
初次 分 配 IP 地 址 的 过 程 。 


在 DHCP 服 务 器 为 DHCP 客 户 端 初 次 提供 下地 址 目 动 分 配 的 整个 过 
程 中 ， 一 共 经 过 了 以 下 4 个 阶段 ， 同 时 利用 了 表 11-9 中 的 前 4 个 报 文 : 
发 现 阶 段 (DHCP 客 户 端 在 网 络 中 广播 发 送 DHCP DISCOVER 请 求 报 
文 ， 发现 DHCP 服 务 器 ， 请 求 IP 地 址 租约 ) 、 提 供 阶段 (DHCP 服 务 器 
通过 DHCP OFFER 报 文 向 DHCP 客 户 端 提 供 卫 地 址 预 分 配 ) 、 选 择 阶 
段 (DHCP 客 户 端 通 过 DHCP REQUEST 报 文 确 认 选 择 第 一 个 DHCP 服 
务 器 为 它 提供 了 地 址 目 动 分 配 服 务 ) 和 确认 阶段 (被 选择 的 DHCP 服 
务 器 通过 DHCP ACK 报 文 把 在 DHCP OFFER 报 文中 准备 的 IP 地 址 租约 
给 对 应 DHCP 客 户 端 ) 。 

在 DHCP 客 户 端 获 得 一 个 下 地 址 后 ， 可 以 发 送 一 个 ARP 请 求 来 避免 
由 于 DHCP 服 务 右 地 址 池 重 车 而 引发 的 IP 冲 突 。 以 上 4 个 阶段 如 图 11-19 


所 示 ， 相 当 于 DHCP 客 户 端 与 DHCP 服 务 器 的 4 次 握手 过 程 ， 有 具体 描述 
如 下 。 


DHCP 客 户 端 DHCP 服 务 需 


DHCP DISCOVER 报 文 (广播 ) 


DHCP OFFER 报 文 (广播 ) 


DHCP QEQUEST 报 文 (广播 ) 


DHCP ACK 报 文 (广播 ) 


11-19 ”DHCP 客户 端 人 DHCP 服务器 获取 IP 地 址 的 4 个 阶段 


1) 发 现 阶 段 ， 即 DHCP 客 户 端 获取 网 络 中 DHCP 服 务 器 信息 的 阶 
段 。 在 客户 端 配 置 了 DHCP 客 户 端 程序 (如 在 Windows 操 作 系 统 中 进行 
了 如 图 11-17 所 示 的 配置 ) 并 启动 后 ， 以 广播 方式 发 送 DHCP 
DISCOVER 报 文 寻找 网 络 中 的 DHCP 服 务 器 。 此 广播 报 文采 用 传输 层 


的 UDP 68 号 端口 发 送 〈 封 装 的 目的 端口 为 UDP 68 号 端口 ) ， 经 过 网 络 
层 IP 封 装 后 ， 源 IP 地 址 为 0.0.0.0 (因为 此 时 还 没有 分 配 IP 地 址 ) ， 目 的 
IP 地 址 为 255.255.255.255 《有 限 广 播 卫 地 址 ) 。 下 面 是 一 个 DHCP 
DISCOVER 报 文 封装 的 IP 报 头 示例 ， 可 以 看 到 Destination Address ( 目 
的 地 址 ) 是 255.255.255.255， 而 Source Address ( 源 地 址 ) 是 0.0.0.0。 
天 于 IP 报 头 中 的 其 他 字段 舍 义 ， 可 以 参见 7.3.4 相 关内 容 。 

IP:Header Length=20(0x14) 


IP:Service Type=0(0Ox0) 
IP:Precedence=Routine 


IP:...0....=Normal Delay 
IP:....0...=Normal Throughput 
下 0..=Normal Reliability 


IP:Total Length=328(0Ox148) 

IP:Identification=0(0Ox0) 

IP:Flags Summary=0(0Ox0) 

TR LS 0=Last fragment in datagram 

TP 区 0.=May fragment datagram If necessary 

IP:Fragment Offset=0(0x0)bytes 

IP:Time to Live=128(0Ox80) 

IP:Protocol=UDP-User Datagram !--- 使 用 UDP 传输 层 协议 

IP:Checksum=0x39A6 

IP:Source Address=0.0.0.0 !--- 源 IP 地 址 为 9.0.0.0 

IP:Destination Address=255.255.255.255 !--- -目的 IP 地 址 为 
255.255.255.255 

IP:Data:Number of data bytes remaining=308(0Ox0134) 


经 验 之 谈 在 上 述 DHCP DISCOVER 报 文中 ，IP 报 关中 的 目的 地 
址 是 255.255.255.255。 这 个 有 限 广 播 地 址 代表 任意 一 个 IPv4 子 网 的 广 
播 地 址 ， 当 然 也 是 发 送 报 文 的 主机 所 在 的 子 网 和 和 DHCP 服务 器 所 在 子 


网 的 广播 地 址 ， 但 此 时 DHCP 客 户 端 并 不 知道 DHCP 服 务 右 处 于 哪个 子 
网 。 下 面 其 他 DHCP 报 文中 的 255.255.255.255 地 址 的 含义 也 是 一 样 的 。 


对 于 IP 报 头 中 的 源 地 址 ， 由 于 当前 DHCP 客 户 端 主 机 并 未 分 配 具 
体 的 IP 地 址 ， 所 以 只 能 用 具有 任意 代表 功能 的 0.0.0.0 地 址 来 表示 了 。 
下 面 其 他 DHCP 报 文中 指定 的 0.0.0.0 地 址 的 含义 也 是 一 样 的 。 


此 时 ， 因 为 DHCP 客 户 端 没有 分 配 到 IP 地 址 ， 也 不 知道 DHCP 服 务 
器 或 DHCP 中 继 的 IP 地 址 ， 所 以 在 DHCP DISCOVER 报 文中 Ciaddr ( 客 
户 端 TP 地 址 ) 、Yiaddr (被 分 配 的 DHCP 客 户 端 1P 地 址 ) 、Siaddr (下 
一 个 为 DHCP 客 户 端 分 配 IP 地 址 的 DHCP 服 务 器 地 址 ) 、Giaddr 

(DHCP 中 继 IP 地 址 ) 这 4 个 字段 均 为 0.0.0.0， 如 下 所 示 。 另 外 ， 从 中 
可 以 看 到 ， 在 CHADDR 字 段 和 DHCP 选 项 的 Client Identifier 字 段 中 都 标 
识 了 DHCP 客 户 病 网 卡 MAC 地 址 。 


DHCP :Discover (xid=21274A1D) 

DHCP :Op Code(op)=1(0Ox1) 

DHCP :Hardware Type(htype)=1(0x1L1)10Mb Ethernet 

DHCP :Hardware Address Length(hlen)=6(0x6) 

DHCP :Hops (hops)=0(0Ox0) 

DHCP :Transaction ID(xid)=556223005(QOx21274A1D) 

DHCP :Seconds (secs)=0(0x0) 

DHCP:Flags(fags)=1(0x1) !--- 标志 位 置 1， 代 表 以 广播 方式 发 送 
DHCPi Less Bi dd ee dn =Broadcast 
DHCP:Client IP Address(ciaddr)=0.0.0., 
DHCP:Your IP Address(yiaddr)=0.0.0.0 
DHCP :Server IP Address(siaddr)=0.0.0., 
DHCP :Relay IP Address(giaddr)=0.0.0.0 
DHCP:Client Ethernet Address(chaddr )=08002B2ED85E 
DHCP :Server Host Name(sname)=<Blank> 

DHCP:Boot File Name(file)=<Blank> 

DHCP :Magic Cookie=[OK] 


0 


0 


DHCP:Option Field(options) 

DHCP:DHCP Message Type=DHCP Discover !--- DHCP 报 文 类 型 为 DHCP 
Discover 

DHCP :Client-identifer=(Type:1)08 00 2b 2e d8 5e 

DHCP :Host Name=JUMBO-WS !--- DHCP 服 务 器 主机 名 

DHCP :Parameter Request List=(Length:7)01 0f 03 2c 2e 2f 06 

DHCP:End of this option field 


2) 提供 阶段 ， 即 DHCP 服 务 器 向 DHCP 客 户 端 提供 预 分 配 IP 地 址 
的 阶段 。 网 络 中 的 所 有 DHCP 服 务 器 接收 到 客户 端的 DHCP 
DISCOVER 报 文 后 ， 都 会 根据 自己 地 址 池 中 了 P 地 址 分 配 的 优先 次 序 选 
出 一 个 IP 地 址 ， 然 后 与 其 他 参数 一 起 通过 传输 层 的 UDP 67 号 端口 ， 在 
DHCP OFFER 报 文中 以 广播 方式 发 送 给 客户 端 (目的 端口 是 DHCP 客 
户 端的 UDP 68 号 端口 ) 。 客 户 端 通过 封装 在 帧 中 的 目的 MAC 地 址 (也 
就 是 DHCP DISCOVER 报 文中 的 CHADDR 字 段 值 ) 的 比 对 过 程 来 确定 
是 否 接收 该 帧 。 但 这 样 一 来 ， 理 论 上 DHCP 窜 户 端 可 能 会 收 到 多 个 
DHCP OFFER 报 文 〈 当 网 络 中 存在 多 个 DHCP 服 务 器 时 ) ， 但 DHCP 客 
户 端 只 接受 第 一 个 到 来 的 DHCP OFFER 报 文 。 


DHCP OFFER 报 文 经 过 IP 封 装 后 的 源 IP 地 址 是 DHCP 服 务 器 上 自己 的 
IP 地 址 ， 目 的 地 址 仍 是 255.255.255.255 广 播 地 址 ， 使 用 的 协议 仍 为 
UDP。 下面 是 一 个 DHCP OFFER 报 文 的 IP 报 头 示例 。 


IP:ID=0Xx3C30;Proto=UDP;Len:328 
IP:Version=4(0Ox4) 

IP:Header Length=20(0Ox14) 
IP:Service Type=0(0Ox0) 
IP:Precedence=Routine 
IP:...0....=Normal Delay 
IP:....0...=Normal Throughput 


IP:...,， 0..=Normal Reliability 

IP:Total Length=328(0Ox148) 
IP:Identification=15408(0Qx3C30) 

IP:Flags Summary=0(0Ox0) 

LP sa 0=Last fragment in datagram 

LP 证 人 0.=May fragment datagram if necessary 
IP:Fragment Offset=0(0x0)bytes 

IP:Time to Live=128(0Ox80) 

IP:Protocol=UDP-User Datagram 
IP:Checksum=0x2FA8 

IP:Source Address=157.54.48.151 

IP:Destination Address=255.255.255.255 
IP:Data:Number of data bytes remaining=308(0Ox0134) 


在 DHCP OFFER 报 文中 ，Ciaddr 字 段 值 仍 为 0.0.0.0， 因 为 客户 端 仍 
没有 分 配 到 IP 地 址 ;Yiaddr 字 段 已 有 值 了 ， 这 是 DHCP 服 务 句 为 该 客户 
端 预 分 配 的 耳 地 址 ; 因为 此 时 仍 没 有 得 到 客户 端 确认 ， 所 以 Siaddr 字 段 
值 仍 为 0.0.0.0; 因为 没有 经 过 DHCP 中 继 服务 器 ， 所 以 Giaddr 字 段 值 仍 
为 0.0.0.0。 男 外 ， 在 DHCP 可 选项 部 分 ， 可 以 看 到 由 服务 絮 随 IP 地 址 一 
起 发 送 的 各 种 选项 。 在 这 种 情况 下 ， 服 务 器 发 送 的 是 子 网 掩 码 、 默 认 
网 关 (路 由 器 ) 、 租 约 时 间 、WINS 服 务 器 地 址 (NetBIOS 名 称 服务 ) 
和 NetBIOS 市 点 类 型 。 下 面 是 一 个 DHCP OFFER 报 文 示例 。 


DHCP :Offer (xid=21274A1D) 

DHCP :Op Code(op)=2(0x2) 

DHCP :Hardware Type(htype)=1(0x1)10Mb Ethernet 
DHCP :Hardware Address Length(hlen)=6(0x6) 
DHCP :Hops (hops)=0(0Ox0) 

DHCP :Transaction ID(Xid)=556223005(0Xx21274A1D ) 
DHCP :Seconds (secs)=0(0x0) 

DHCP :Flags(flags)=1(0Ox1) 

DHCP SS Lew 3 i =Broadcast 

DHCP :Client IP Address(ciaddr)=0.0.0.0 
DHCP:Your IP Address(yiaddr)=157.54.50.5 

DHCP :Server IP Address(siaddr)=0.0.0.0 

DHCP :Relay IP Address(giaddr)=0.0.0.0 


DHCP:Client Ethernet Address(chaddr )=08002B2ED85E 

DHCP:Server Host Name(sname)=<Blank> 

DHCP:Boot File Name(file)=<Blank> 

DHCP :Magic Cookie=[OK] 

DHCP :Option Field(options) 

DHCP:DHCP Message Type=DHCP 0ffer !--- DHCP 报 文 类 型 为 DHCP OFFER 

DHCP :Subnet Mask=255.255.240.0 

!--- 所 分 配 IP 地 址 的 子 网 掩 码 为 255 .255.240.0 

DHCP :Renewal Time Value(T1)=8 Days,0:00:00 

!--- 想 要 继续 租约 原来 分 配 的 IP 地 址 ， 则 en 

DHCP :Rebinding Time Value(T2)=14 Days,o: 00 

!--- 如 果 上 次 申请 续 约 失败 ， 再 次 申请 绑 定 原来 分 本 到 的 TP 地址 的 期 限 为 14 天 

DHCP:IP Address Lease Time=16 Days,0:00:00 

!--- 租约 期 限 为 16 天 ， 也 就 是 DHCP 客 户 端 可 使 用 此 IP 地 址 的 最 长 时 间 为 16 天 

DHCP:Server Identifer=157.54.48.151 !--- DHCP 服 务 器 的 IP 地 址 为 
157.54.48.151 

DHCP :Router=157.54.48.1 !--- 默认 网 关 IP 地 址 为 157 .54.48.1 

DHCP :NetBIOS Name Service=157.54.16.154 !--- DNS 服 务 器 IP 地 址 为 
157.54.16.154 

DHCP :NetBIOS Node Type=(Length:1)04 

DHCP:End of this option field 


3) 选择 阶段 ， 即 DHCP 客 户 端 选 择 IP 地 址 的 阶段 。 如 果 有 多 台 
DHCP 服 务 器 向 该 客户 端 发 来 DHCP OFFER 报 文 ， 则 该 客户 端 只 接受 
第 一 个 收 到 的 DHCP OFFER 报 文 ， 然 后 以 广播 方式 发 送 DHCP 
REQUEST 报 文 。 在 该 报 文 的 “Requested Address” 选 项 中 ， 包 含 DHCP 
服务 器 在 DHCP OFFER 报 文中 预 分 配 的 IP 地 址 、 对 应 的 DHCP 服 务 器 IP 
地 址 等 。 这 样 也 就 相当 于 同时 告诉 其 他 DHCP 服 务 器 ， 它 们 可 以 释放 
已 提供 的 地 址 ， 并 将 这 些 地 址 返回 到 可 用 地 址 池 中 。 


在 DHCP OFFER 报 文 封 装 的 卫 头 部 中 ， 客 户 端 的 源 地 址 仍 是 
0.0.0.0， 数 据 包 的 目的 地 址 仍 是 255.255.255.255。 但 在 DHCP OFFER 报 


文中 ，Ciaddr、Yiaddr、Siaddr、Giaddr 字 上 段 的 地 址 均 0.0.0.0。 下 面 是 
一 个 DHCP OFEER 报 文 头 部 和 DHCP OFFER 报 文 示例 。 


IP:ID=O0x100;Proto=UDP; Len:328 
IP:Version=4(0Ox4) 

IP:Header Length=20(0Ox14) 
IP:Service Type=0(0Ox0) 
IP:Precedence=Routine 


IP:...0....=Normal Delay 
IP:....0...=Normal Throughput 
IP:..... 0..=Normal Reliability 


IP:Total Length=328(0Ox148) 
IP:Identification=256(0X100 ) 

IP:Flags Summary=0(0Ox0) 

1 0=Last fragment in datagram 

于 恨 EE 0.=May fragment datagram if necessary 
IP:Fragment Offset=0(0x0)bytes 

IP:Time to Live=128(0Ox80) 

IP:Protocol=UDP-User Datagram 
IP:Checksum=0x38A6 

IP:Source Address=0.0.0.0 

IP:Destination Address=255.255.255.255 
IP:Data:Number of data bytes remaining=308(0Ox0134) 
DHCP :Request (xid=21274A1D) 

DHCP :Op Code(op)=1(0Ox1) 

DHCP :Hardware Type(htype)=1(0x1L1)10Mb Ethernet 
DHCP :Hardware Address Length(hlen)=6(0x6) 

DHCP :Hops (hops)=0(0Ox0) 

DHCP :Transaction ID(xid)=556223005(QOx21274A1D) 
DHCP :Seconds (secs)=0(0x0) 

DHCP :Flags(flags)=1(0Ox1) 

DHCBS Ls Dh =Broadcast 


DHCP :Client IP Address(ciaddr)=0.0.0.0 
DHCP:Your IP Address(yiaddr)=0.0.0.0 
DHCP :Server IP Address(siaddr)=0.0.0.0 


DHCP :Relay IP Address(giaddr)=0.0.0.0 

DHCP:Client Ethernet Address(chaddr )=08002B2ED85E 
DHCP:Server Host Name(sname)=<Blank> 

DHCP:Boot File Name(file)=<Blank> 

DHCP :Magic Cookie=[OK] 

DHCP :Option Field(options) 

DHCP:DHCP Message Type=DHCP Request 

DHCP :Client-identifier=(Type:1)08 00 2b 2e d8 5e 
DHCP :Requested Address=157.54.50.5 


DHCP:Server Identifer=157.54.48.151 

DHCP :Host Name=JUMBO-WS 

DHCP :Parameter Request List=(Length:7)01 0f 03 2c 2e 2f 06 
DHCP:End of this option field 


4) 确认 阶段 : 即 DHCP 服 务 器 确认 分 配 DHCP 客 户 端 了 了 地 址 的 阶 
段 。 某 个 DHCP 服 务 器 在 收 到 DHCP 客 户 端 发 来 的 DHCP REQUEST 报 
文 后 ， 只 有 DHCP 客 户 端 选择 的 服务 器 会 进行 如 下 操作 :如果 确认 将 
地 址 分 配给 该 客户 端 ， 则 以 广播 方式 返回 DHCP ACK 报 文 ; 否则 返回 
DHCP NAK 报 文 ， 表 明 地 址 不 能 分 配给 该 客户 端 。 


在 DHCP 服 务 絮 发 送 的 DHCP ACK 报 文 的 IP 头 部 ，Source Address 

是 DHCP 服 务 器 IP 地 址 ，Destination Address 仍 然 是 广播 地 址 
255.255.255.255。 在 DHCP ACK 报 文中 的 Yiaddr 字 段 ， 包 舍 要 分 配给 
户 端 的 IP 地 址 ， 而 ChADDR 和 DHCP:Client Identifier 字 段 是 发 出 请 求 的 
客户 端 中 网 卡 的 MAC 地 址 。 同 时 ， 在 选项 部 分 也 会 在 DHCP OFFER 报 
文中 把 所 分 配 的 IP 地 址 的 子 网 掩 码 、 默 认 网 关 、DNS 服 务 器 、 租 约 
期 、 续 约 时 间 等 信息 加 上 。 

eno) 

IP:Header Length=20(0x14) 


IP:Service Type=0(0Ox0) 
IP:Precedence=Routine 


IP:...0....=Normal Delay 
IP:....0...=Normal Throughput 
a 0..=Normal Reliability 


IP:Total Length=328(0Ox148) 
IP:Identification=15664(0Qx3D30) 
IP:Flags Summary=0(0Ox0) 

TR 0=Last fragment in datagram 


IP: 


a 0.=May fragment datagram if necessary 
:Fragment Offset=0(0Ox0)bytes 

:Time to Live=128(0Ox80) 

:Protocol=UDP-User Datagram 

:Checksum=0x2EA8 

:Source Address=157.54.48.151 

:Destination Address=255.255.255.255 

Data:Number of data bytes remaining=308(0Ox0134) 


DHCP :ACK(xid=21274A1D) 

DHCP :Op Code(op)=2(0x2) 

DHCP :Hardware Type(htype)=1(0x1)10Mb Ethernet 
DHCP :Hardware Address Length(hlen)=6(0x6) 
DHCP :Hops (hops)=0(0Ox0) 

DHCP :Transaction ID(xid)=556223005(QOx21274A1D) 
DHCP :Seconds (secs)=0(0x0) 

DHCP :Flags(flags)=1(0Ox1) 

DHGP sil snr ss Re =Broadcast 

DHCP:Client IP Address(ciaddr)=0.0.0.0 

DHCP :Your IP Address(yiaddr )=157.54.50.5 

DHCP :Server IP Address(siaddr)=0.0.0.0 

DHCP :Relay IP Address(giaddr)=0.0.0.0 
DHCP:Client Ethernet Address(chaddr )=08002B2ED85E 
DHCP :Server Host Name(sname)=<Blank> 
DHCP:Boot File Name(file)=<Blank> 

DHCP :Magic Cookie=[OK] 

DHCP :Option Field(options) 

DHCP :DHCP Message Type=DHCP ACK 

DHCP :Renewal Time Value(T1)=8 Days,0:00:00 
DHCP :Rebinding Time Value(T2)=14 Days,0:00:00 
DHCP:IP Address Lease Time=16 Days,0:00:00 
DHCP :Server Identifer=157.54.48.151 

DHCP :Subnet Mask=255.255.240.0 

DHCP :Router=157.54.48.1 

DHCP :NetBIOS Name Service=157.54.16.154 

DHCP :NetBIOS Node Type=(Length:1)04 

DHCP:End of this option field 


说 明 ”客户 端 在 收 到 服务 器 返回 的 DHCP-ACK 确 认 报 文 后 ， 会 以 
广播 的 方式 发 送 免费 (gratuitous) ARP 报 文 (该 报 文中 ， 源 IP 地 址 和 
日 标 IP 地 址 都 是 本 机 IP 地 址 ， 源 MAC 地 址 是 本 机 MAC 地 址 ， 目 的 
MAC 地 址 是 广播 MAC 地 址 ) ， 探 测 是否 有 主机 使 用 服务 器 分 配 的 IP 地 


址 ， 如 果 在 规定 的 时 间 内 没有 收 到 回应 ， 客 户 端 才 使 用 此 地 址 。 否 
则 ， 客 户 端 会 发 送 DHCP DECLINE 报 文 给 DHCP 服 务 器 ， 并 重新 申请 
IP 地 址 。 


如 有 果 网 络 中 存在 多 个 DHCP 服 务 右 ， 除 DHCP 客 户 端 光 中 的 服务 器 
外 ， 其 他 DHCP 服 务 器 中 本 次 未 分 配 出 的 人 P 地 址 仍 可 分 配给 其 他 客户 


端 。 


11.4.5 ”DHCP 服务 的 IP 地 址 租约 更 新 原理 


如 有 条 采用 动态 下地 址 分 配 策 略 ， 则 DHCP 服 务 右 分 配给 客户 端的 了 
地 址 都 是 有 一 定 的 租约 期 限 的 ， 当 租约 期 满 后 ，DHCP 服 务 吉 又 会 收 
回 原来 分 配 的 这 个 IP 地 址 。 如 果 DHCP 客 户 端 希望 继续 使 用 该 地 址 ， 
则 需要 向 DHCP 服 务 器 提出 更 新 JP 地址 租约 的 申请 ， 也 就 是 前 面 所 说 
的 “ 续 约 *。IP 地 址 租约 更 新 ， 或 者 IP 地 址 续 约 也 就 是 更 新 服务 絮 端 对 
IP 地 址 的 租约 信息 ， 使 其 恢复 为 初始 状态 。 申 请 续 约 的 步骤 如 下 : 


1) 在 DHCP 客 户 端的 卫 地 址 租约 期 限 达到 1/2 时 ， 由 DHCP 客 户 端 
回 为 它 分 配 卫 地址 的 DHCP 服 务 恬 以 单 播 方式 发 送 DHCP REQUEST 请 
求 报 文 ， 以 期 进行 IP 租 约 的 更 新 。 


2) 如 果 DHCP 服 务 器 同意 续 约 ， 则 DHCP 服 务 器 向 客户 端 以 单 播 
方式 返回 DHCP ACK 报 文 ， 通 知 DHCP 客 户 端 已 经 获得 新 IP 租 约 ， 可 
以 继续 使 用 此 IP 地 址 ; 相反 ， 如 果 DHCP 服 务 器 不 同意 续 约 ， 则 DHCP 
服务 器 以 单 播 方式 返回 DHCP NAK 报 文 ， 通 知 DHCP 客 户 端 不 能 获得 
新 的 租约 ， 此 耳 地 址 不 可 以 再 分 配给 该 客户 端 。 


3) 如 果 上 面 的 续 约 申请 失败 ， 则 DHCP 客 户 端 还 会 在 租约 期 限 达 
到 7/8 时 ， 再 次 以 广播 方式 发 送 DHCP REQUEST 请 求 报 文 进行 续 约 。 
DHCP 服 务 器 的 处 理 方式 同上 ， 不 再 警 述 。 


如 有 果 第 二 次 续 约 请 求 还 是 失败 的 ， 则 原来 租约 的 人 P 地 址 将 被 释 
放 。 


11.4.6 ”DHCP 中 继 代 理 服务 


在 DHCP 客 户 端 初次 从 DHCP 服 务 器 获取 IP 地 址 的 过 程 中 ， 所 有 从 
DHCP 客 户 端 发 出 的 请 求 报 文 和 所 有 由 DHCP 服 务 器 返回 的 应 答 报 文 均 
是 以 广播 方式 (目的 地 址 为 255.255.255.255) 进行 发 送 的 ， 因 此 ， 
DHCP 服 务 只 适用 于 DHCP 客 户 端 和 DHCP 服 务 器 处 于 同一 个 子 网 (也 
就 是 DHCP 服 务 器 至 少 有 一 个 端口 是 与 DHCP 客 户 端 所 在 子 网 直接 连接 
的 ) 的 情况 ， 因 为 广播 包 是 不 能 穿越 子 网 的 。 


基于 DHCP 服 务 的 以 上 限制 ， 如 果 DHCP 客 户 疹 气 DHCP 服 务 右 之 
间 存 在 路 由 器 设备 ， 不 在 同一 子 网 ， 束 不 能 直接 通过 这 人 台 DHCP 服 务 器 
获取 IP 地 址 ， 即 使 DHCP 服 务 器 上 已 配置 了 对 应 的 地 址 池 。 这 也 就 意味 
着 ， 如 有 果 想 要 让 多 个 子 网 中 的 主机 进行 动态 IP 地 址 分 配 ， 就 需要 在 网 
络 中 的 所 有 子 网 中 都 设置 一 个 DHCP 服 务 器 ， 这 显然 是 很 不 合算 的 ， 也 
是 没有 必要 的 。 


DHCP 中 继 功能 可 以 很 好 地 解决 DHCP 服 务 的 以 上 难题 。 通 过 
DHCP 中 继 代 理 服务 ， 与 DHCP 服 务 右 不 在 同一 子 网 的 DHCP 客 户 端 可 
以 通过 DHCP 中 继 代 理 〈 通 常 由 路 器 或 三 层 交 换 机 设备 担当 ， 但 需要 开 
局 DHCP 中 继 功 能 ) 与 位 于 其 他 网 段 的 DHCP 服 务 器 通信 ， 最 终 使 
DHCP 客 户 端 获 取 到 从 DHCP 服 务 种 上 分 配 而 来 的 卫 地 址 。 此 时 的 
DHCP 中 继 代 理 束 位 于 DHCP 客 户 问 和 DHCP 服 务 絮 之 间 ， 人 负责 广 播 


DHCP 报 文 的 转发 ， 如 图 11-20 所 示 。 显 然 ，DHCP 中 继 代理 必须 有 一 个 
端口 连接 了 DHCP 客 户 端 所 在 子 网 ， 另 一 端 又 直接 连接 了 DHCP 服 务 器 
所 在 子 网 。 当 然 ， 一 个 DHCP 中 继 代理 可 以 同时 连接 多 个 子 网 ， 作 为 多 
个 DHCP 客 户 端子 网 的 中 继 代 理 。 这 样 ， 多 个 子 网 上 的 DHCP 客 户 端 又 
可 以 使 用 同一 个 DHCP 服 务 器 来 自动 分 配 卫 地 址 ， 既 节省 了 成 本 ， 又 便 
于 集中 管理 。 


DHCP 客户 端 


IP network 


DHCP 中 继 代 理 


DHCP 服务 器 
图 11-20 ”DHCP 中 继 代 理 的 典型 应 用 示例 
经 验 之 谈 ”其 实 这 里 的 DHCP 中 继 代 理 相 当 于 网 关 ，DHCP 广 播报 
文 都 是 通过 这 个 网 关 来 进行 转发 的 。DHCP 中 继 代 理 服 务 的 典型 应 用 环 


境 就 是 一 个 DHCP 服 务 器 为 所 连接 的 交换 机 上 的 多 个 VLAN 分 配 IP 地 
址 。 这 时 因为 DHCP 服 务 絮 只 能 属于 一 个 VLAN， 所 以 要 为 多 个 VLAN 


同时 分 配 耳 地 址 的 话 ， 束 必须 在 这 些 VLAN 与 DHCP 服 务 器 之 间 设 置 一 
个 DHCP 中 继 代 理 ， 那 就 是 需要 在 三 层 交 换 机 上 开启 DHCP 中 继 代 理 服 
务 ， 让 三 层 交 换 机 充当 DHCP 中 继 代理 角色 。 然 后 ， 在 DHCP 服 务 右上 
启用 802 选 项 (用 于 识别 DHCP 中 继 代 理 ) ， 并 在 每 个 地 址 池 中 为 每 个 
子 网 配置 一 个 默认 网 关 地 址 (各 VLAN 接 口 IP 地 址 ) 即 可 。 


1.DHCP 中 继 代理 简介 


Option 82 是 DHCP 报 文中 的 中 继 代理 信息 选项 (relay agent 
information option) ， 该 选项 记录 了 DHCP 客 户 端 的 位 置信 息 。 管 理 员 
可 以 利用 该 选项 定位 DHCP 客 户 端 ， 实 现 对 客户 端的 安全 和 计 费 等 控 
制 。 文 持 Option 82 选 项 的 DHCP 服 务 句 还 可 以 根据 该 选项 的 信息 制定 IP 
地 址 和 其 他 参数 的 分 配 策略 ， 提 供 更 加 灵活 的 地 址 分 配方 式 。 


在 整个 Option 82 选 项 中 ， 最 多 又 可 以 包 偏 255 个 子 先 项 ， 但 至 少 要 
定义 一 个 子 选 项 。 目 前 设备 主要 只 支持 两 个 子 选项 : sub-option 1 
(Circuit ID， 电 路 ID 子 选项 ) 和 sub-option 2 (Remote ID， 远 程 ID 子 选 
项 ) 。 由 于 RFC 3046 对 于 Option 82 的 内 容 没 有 统一 规定 ， 因 此 不 同 厂 
商 通 常 根 据 需 要 进行 填充 。 目 前 ，DHCP 中 继 设备 都 支持 Option 82 子 选 
项 的 扩展 填充 格式 。 


sub-option 1 和 sub-option 2 两 个 子 选 项 格式 分 别 如 图 11-21 和 图 11-22 
所 示 ， 其 中 国定 字段 (相当 于 子 选项 头 ) 括号 中 的 内 容 为 该 字段 的 固 


定 取 值 。sub-option 1 子 选 项 中 的 内 容 是 接收 到 DHCP 客 户 端 请 求 报 文 的 
端口 所 属 VLAN 的 编号 (对 应 “VLAN ID” 字 段 ， 占 2 字 节 ) 以 及 端口 索 
引 (端口 索引 的 取 值 为 端口 物理 编号 减 1， 对 应 “Port Index” 字 段 ， 占 2 
字 节 ) 。sub-option 2 子 选 项 的 内 容 是 接收 到 DHCP 客 户 端 请 求 报 文 的 
DHCP 中 继 设 备 的 MAC 地 址 (对 应 “MAC Address” 字 段 ， 占 6 字 人 ) 。 


0 7 15 23 31 bit 


Sub—option Type (0x01) Length (0x06) ] Circult ID (Ox00) Circuit ID Length (0x04) 


VLAN ID ] Port Index 


图 11-21 sub-option 1 子 选 项 格式 及 默认 填充 


0 7 13 23 31 bit 


Sub—option Type oo Length (Ox06) | Circuit ID (Ox00) Circuit ID Length (Ox04) 


MAC Address 


| 


图 11-22 sub-option 2 子 选 项 格式 及 默认 填充 


2. 通 过 DHCP 中 继 代 理 动 态 分 配 IP 地 址 的 原理 


DHCP 客 户 端 通过 DHCP 中 继 代 理 服 务 从 DHCP 服 务 器 动态 获取 IP 
地 址 的 过 程 与 11.3.4 节 中 介绍 的 不 通过 DHCP 中 继 代 理 而 直接 从 DHCP 服 
务 名 动态 获取 IP 地 址 的 过 程 基本 相同 ， 都 要 经 历 发 现 、 提 供 、 选 择 和 
确认 4 个 阶段 。 其 中 所 用 的 到 报 文 也 对 应 是 DHCP DISCOVER、DHCP 


OFFER、DHCP REQUEST、DHCP ACK， 只 是 在 这 里 DHCP 中 继 代理 
需要 充当 一 个 中 介 代 理 的 角色 ， 负 责 转发 DHCP 客 户 端 与 DHCP 服 务 器 
之 间 交 互 的 这 些 报 文 ， 基 本 流程 如 图 11-23 所 示 。 


DHCP 客 户 端 DHCP 中 继 代 理 DHCP 服 务 器 
DHCP DISCOVER 报 文 (广播 ) 


转发 的 DHCP DISCOVER 报 文 
( 单 播 ) 


DHCP OFFER 报 文 ( 单 播 ) 


转发 的 DHCP OFFER 报 文 (广播 ) 


DHCP REQUEST 报 文 (广播 ) 


转发 的 DHCP REQUEST 报 文 


DHCP ACK 报 文 ( 单 播 ) 


转发 的 DHCP ACK 报 文 (广播 ) 


图 11-23 DHCP 中 继 代 理 基本 流程 


说 明 ”在 如 图 11-23 所 示 的 流程 中 ，DHCP 客 户 端 发 送 的 请 求 报 文 
有 两 种 ， 分 别 为 DHCP DISCOVER 报 文 和 DHCP REQUEST 报 文 。 由 于 
不 同 厂 商 生 产 的 DHCP 服 务 器 设备 对 请 求 报 文 的 处 理 机 制 不 同 ， 有 些 设 


备 处 理 DHCP DISCOVER 报 文中 的 Option 82 人 信息， 而 有 些 处 理 DHCP 
REQUEST 报 文中 的 Option 82 信 息 ， 因 此，DHCP 中 继 设 备 将 在 这 两 种 
报 文 中 都 添加 Option 82 选 项 。 


这 里 将 只 介绍 DHCP 中 继 支 持 Option 82 时 的 工作 机 制 ， 具 体 如 下 : 


1) DHCP 客 户 端 以 广播 方式 (因为 不 知道 中 继 代 理 设备 的 IP 地 
址 ) 向 本 网 段 发 送 DHCP DISCOVER 或 DHCP REQUEST 请 求 报 文 。 此 
时 ， 只 有 网 络 中 的 DHCP 中 继 代 理 设备 会 接收 该 DHCP 请 求 报 文 (假设 
本 网 段 中 没有 DHCP 服 务 器 ) 。 


2) DHCP 中 继 代 理 设备 在 收 到 DHCP 客 户 端 发 来 的 DHCP 
DISCOVER 或 DHCP REQUEST 请 求 报 文 后 ， 将 检查 报 文 中 是 否 已 有 
Option 82 选 项 (主要 是 前 面 介绍 的 sub-option 1 子 选 项 和 sub-option 2 子 
选项 ) 。 


如 果 请 求 报 文中 已 有 Option 82， 则 DHCP 中 继 代理 设备 会 按照 配置 
的 策略 对 该 报 文 进行 处 理 (丢弃 ， 或 者 用 中 继 设 备 本 喘 的 Option 82 选 
项 奉 代 报 文中 原 有 的 Option 82 选 项 ， 或 者 保持 报 文 原 有 的 Option 82 选 
项 ) 。 同 时 ， 根 据 Option 82 选 项 的 sub-option 1 子 选项 中 的 VLAN ID 和 
Port Index 字段 配置 ， 找 到 为 对 应 网 段 分 配 的 DHCP 服 务 右 地 址 ， 并 将 请 
求 报 文中 的 giaddr 字 段 填充 为 DHCP 中 继 代 理 设备 的 IP 地 址 ， 然 后 将 请 


求 报 文 以 单 播 方式 (因为 在 中 继 代理 设备 中 已 配置 好 了 对 应 的 DHCP 服 
务 器 地 址 ) 转发 给 指定 的 DHCP 服 务 器 。 


如 果 请 求 报 文 中 没有 Option 82 选 项 ， 则 DHCP 中 继 设 备 将 Option 82 
选项 添加 到 报 文 中 后 ， 根 据 Option 82 选 项 的 sub-option 1 子 选 项 中 的 
VLAN ID 和 Port Index 字 段 配 置 ， 找 到 为 对 应 网 段 分 配 的 DHCP 服 务 器 
地 址 ， 并 将 报 文 中 的 giaddr 字 段 填 充 为 DHCP 中 继 代理 设备 的 耳 地 址 ， 
然后 同样 根据 中 继 代 理 设备 中 为 对 应 网 段 配 置 的 DHCP 服 务 名 地址 以 单 
播 方式 将 请 求 报 文 转发 给 DHCP 服 务 器 。 


3) DHCP 服 务 器 在 收 到 由 DHCP 中 继 代 理 设备 转发 的 DHCP 
DISCOVER 或 DHCP REQUEST 请 求 报 文 后 ， 根 据 转发 的 请 求 报 文中 的 
giaddr 字 上段 值 所 对 应 的 中 继 代 理 设备 IP 地 址 ， 以 及 在 Option 82 选 项 的 
sub-option 2 子 选 项 中 的 中 继 代 理 MAC 地 址 ， 以 单 播 方式 向 DHCP 中 继 
代理 返回 对 应 的 DHCP OFFER 或 者 DHCP ACK 应 答 报 文 。 


4) DHCP 中 继 设备 在 收 到 DHCP 服 务 器 的 应 答 报 文 后 ， 将 剥离 报 文 
中 的 Option 82 信 息 ， 然 后 以 广播 方式 将 融 有 DHCP 配 置信 息 的 对 应 应 答 
报 文 转发 给 DHCP 客 户 端 ， 完 成 对 客户 端的 动态 配置 。 


在 以 上 过 程 中 ，4 种 DHCP 报 文中 除 Option 82 选 项 和 giaddr 字 段 外 ， 
其 他 各 字段 值 均 与 11.3.4 世 介绍 的 非 中 继 方式 动态 分 配子 地 址 过 程 中 的 4 
种 报 文 所 对 应 的 字段 值 是 一 样 的 。 


11.5 ”电子 邮件 服务 


电子 邮件 服务 (E-mail 服务 ) 类 似 于 传统 的 邮件 服务 (如 中 国 邮政 
集团 、 各 家 快递 公司 提供 的 信件 、 包 圳 邮寄 服务 ) ， 只 是 它 是 电子 化 
的 ， 不 仅 需要 邮寄 的 文件 要 电子 化 〈 也 就 是 计算 机 文件 ) ， 而 且 邮 寄 
的 方式 也 要 电子 化 (通过 互联 网 邮寄 ) 。 电 子 邮件 服务 目 20 世 纪 90 年 
代 得 到 普及 后 ， 传 统 的 邮件 服务 和 电报 服务 都 受到 了 很 大 冲击 ， 因 为 
电子 邮件 服务 比 传统 邮件 服务 更 快 ， 可 靠 性 更 高 ， 最 重要 的 是 免费 
的 ， 只 要 有 互联 网 接 入 的 地 方 部 可 以 随时 收 、 发 电子 邮件 。 


11.5.1 电子 邮件 系统 的 基本 结构 


电子 邮件 服务 也 是 一 种 基于 C/S 模 式 的 服务 ， 因 此 ， 它 也 分 为 电子 
邮件 客户 端 和 电子 邮件 服务 器 。 但 是 要 注意 的 是 ， 其 实在 完整 的 电子 
邮件 系统 中 ， 包 括 发 件 方 和 收 件 方 都 会 包括 一 父 客 户 关 和 服务 铸 系 
统 。 电 子 邮 件 不 是 直接 从 发 送 方 传输 到 接收 方 的 ， 而 是 通过 双方 的 电 
子 邮件 服务 夯 转 发 、 保 存 。 这 时 ， 各 目的 电子 邮件 服务 融融 相当 于 一 
个 存储 电子 邮件 的 “仓库 ?和 用 于 非 即时 电子 邮件 转发 的 中 转 站 。 这 样 
做 有 两 方面 的 好 处 : 


口 用 户 不 必 时 刻 在 线 等 竺 电子 邮件 的 到 来 ， 这 个 工作 直接 由 目 己 
选择 的 电子 邮件 服务 絮 来 完成 ， 因 为 电子 邮件 服务 絮 ， 特 别 是 ISP 提 供 
的 电子 邮件 服务 句 是 每 天 24 小 时 不 天 机 的 。 电 子 邮 件 服务 器 可 以 每 天 
24 小 时 随时 接收 ， 并 保存 用 户 的 电子 邮件 ， 用 户 想 何 时 收 邮 件 都 可 
以 。 


口 用 户 目 己 不 必 识 别 互联 网 上 的 各 种 各 样 的 电子 邮件 域名 ， 这 个 
工作 也 全 部 交 给 由 ISP 提 供 的 电子 邮件 服务 器 完成 。 这 样 可 大 大 降低 电 
子 邮件 用 户主 机 的 配置 难度 ， 只 需 安 装 一 个 电子 邮件 客户 端 软件 ， 然 
后 在 客户 端 中 配置 好 自己 申请 的 ISP 电 子 邮箱 账户 ， 以 及 对 应 的 电子 邮 
件 服务 万 地 址 。 


整个 电子 邮件 系统 包括 “用 户 代 理 ” (user agent) 和 “消息 传输 代 

理 ”(message transfer agent) 两 大 部 分 。“ 用 户 代 理 ” 负 责 电 子 邮 件 用 户 
书写 、 发 送 、 接 收 和 阅读 电子 邮件 ， 是 安装 在 用 户 端 上 的 各 种 电子 邮 
件 客 户 端 软件 ， 是 用 户 与 电子 邮件 系统 间 交 互 的 本 地 程序 。“ 消 息 传输 
代理 ”负责 电子 邮件 在 发 件 方 的 客户 端 和 收 件 方 的 服务 右 端 之 间 ， 以 及 
在 发 件 方 的 服务 器 端 与 收 件 方 的 服务 器 端 之 间 的 传输 ， 是 安装 在 ISP 或 
者 本 地 网 络 中 的 各 种 电子 邮件 服务 名 软件 。“ 消 居 传 输 代 理 ” 也 称 “ 守 护 
进程 ”(daemon) ， 是 在 服务 器 程序 后 台 运 行 的 应 用 服务 进程 。 基 本 电 
子 邮 件 系 统 结构 如 图 11-24 所 示 。 
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图 11-24 基本 电子 邮件 系统 结构 


与 其 他 计算 机 网 络 应 用 服务 一 样 ， 电 子 邮件 服务 也 是 由 一 些 具体 
的 应 用 层 协 议 来 实现 的 。 目 前 ,提供 电子 邮件 发 送 服 务 的 协议 主要 是 
SMTP (Simple Mail Transfer Protocol， 简 单 邮件 传输 协议 ) ， 而 提供 邮 
件 接收 服务 的 协议 主要 是 POP3 (Post Office Protocol 3， 邮 局 协议 3) 。 
它们 都 是 工作 于 C/S 模 式 的 ， 都 有 对 应 的 客户 端 和 服务 器 端 两 部 分 。 
在 “用 户 代理 ”部 分 会 同时 提供 SMTP 客 户 端 和 POP3 客 户 端 服 务 ， 而 
在 “消息 传输 代理 ”部 分 则 除了 包括 SMTP 服 务 器 和 POP3 服 务 器 外 ， 还 要 
包括 SMTP 客 户 端 ， 因 为 在 发 送 和 接收 邮件 两 方 的 邮件 服务 器 之 间 还 需 
要 进行 电子 邮件 传输 。 


说 明 在 此 ， 仅 以 SMTP 和 POP3 这 两 种 应 用 最 广 的 电子 邮件 协议 
为 例 进行 介绍 。 除 此 之 外 ， 提 供电 子 邮 件 发 送 服 务 的 协议 还 有 MIME 
(Multipurpose Internet Mail Extensions， 多 用 途 互 联网 邮件 扩展 ) ， 提 


供 邮 件 接收 服务 的 协议 还 有 IMAP (Internet Mail Access Protocol， 互 联 
网 邮件 访问 协议 ) 。 具 体内 容 将 在 本 章 后 面 介绍 。 


图 11-25 显 示 了 一 个 完整 的 9MTP/POP3 电 子 邮件 传输 系统 ， 包 括 发 
件 方 和 收 件 方 各 自 的 电子 邮件 系统 及 组 成 。 在 发 件 人 和 收 件 人 计算 机 
会 安装 各 种 用 于 电子 邮件 收发 的 电子 邮件 客户 端 软件 ， 也 惑 是 用户 
代理 ”， 如 outlook、foxmail 等 。 在 这 类 软件 中 会 全 面包 括 SMTP 客 户 端 
和 POP3 客 户 端 程序 ， 因 为 一 般 用 户 不 可 能 通过 此 程序 只 发 送 ， 或 者 只 
接收 电子 邮件 。 
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图 11-25 ” SMTP/POP3 电 子 邮 件 传输 系统 
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在 发 件 方 和 收 件 方 邮件 服务 器 中 会 安装 各 种 电子 邮件 服务 器 软 
件 ， 也 就 是 “消息 传输 代理 ”部 分 ， 如 Exchange Server、SendMial 、 
WinMail、CCMail 等 。 在 电子 邮件 服务 器 软件 中 会 同时 提供 SMTP 服 务 
器 、POP3 服 务 器 和 SMTP 客 户 端 ， 因 为 一 个 电子 邮件 服务 器 既 要 把 由 
用 户主 动 发 送 过 来 的 电子 邮件 转发 到 接收 方 的 电子 邮件 服务 器 中 〈 需 


要 同时 利用 SMTP 客 户 端 和 SMTP 服 务 器 ) ， 又 要 允许 用 户 从 电子 邮件 
服务 器 上 取 回 自己 的 电子 邮件 (利用 的 是 POP3 客 户 端 ) 。 


SMTP 和 POP3 服 务 都 是 使 用 TCP 传 输 层 协议 进行 邮件 传输 的 ， 各 自 
使 用 的 端口 分 别 为 TCP 25 和 TCP 110。 在 如 图 11-25 所 示 的 电子 邮件 系 
统 中 ， 电 子 邮 件 的 发 送 和 接收 都 是 通过 TCP 进 行 的 ， 具 体 的 工作 原理 将 
在 本 章 后 面 介绍 。 


11.5.2 ”电子 邮件 消息 格式 


要 书写 和 阅读 电子 邮件 ， 必 须 先 规定 标准 的 电子 邮件 消息 格式 。 
电子 邮件 消息 格式 最 开始 是 在 RFC822 中 规定 的 ， 这 是 纯 ASCII 煤 体 类 
型 的 ， 后 来 有 改进 版 的 RFC2822， 以 及 扩展 的 MIME (多 用 户 互联 网 邮 
件 扩展 ) 格式 。 本 节 主 要 介绍 RFC2822 电 子 邮件 消息 格式 和 MIME 电 子 
邮件 消息 格式 。 


1.RFC2822 电 子 邮 件 消 轧 格 式 


在 RFC2822 中 规定 ， 一 封 电 子 邮 件 分 成 两 个 基本 部 分 :一 个 信和 直 
(也 称 “ 邮 件 头 部 ”) 、 邮 件 正 文 ， 如 图 11-26 所 示 。 其 实 它 就 是 一 个 表 
单 o 


收 件 人 信封 部 分 


抄 送 


邮件 正文 


图 11-26 ”RFC2822 电 子 邮 件 消息 格式 


在 “信封 ?部 分 包括 多 个 消息 头 ， 每 个 消息 头 占 一 行 ， 每 行 包括 一 
个 关键 字 (keyword) 和 一 个 对 应 的 值 (value) ， 中 间 用 冒号 (:) 分 
隔 。 和 常用 的 关键 字 包 括 : Date (邮件 发 送 日 期 ，、From (发 件 人 ) 、 
Subject (邮件 标题 ) 、Sender ( 写 信人 ) 、To ( 收 件 人 ) 、Cc ( 抄 
送 ) 、Bcc ( 密 送 ) 、Reply-To (回信 地 址 ) 等 。 在 Subject 关 键 字 后 ， 
每 次 回复 都 在 前 面 加 上 一 个 “Re”， 从 中 可 以 看 出 这 是 第 几 次 回复 ; 


Reply-To 天 键 字 后 面 跟 的 邮箱 地 址 可 以 与 From 天 键 字 后 面 跟 的 发 信人 
邮箱 地 址 相同 ， 也 可 以 不 同 ， 因 为 有 的 用 户 有 不 同 的 发 送 邮件 地 址 和 
接收 邮件 地 址 ;在 “信封 ?部 分 中 的 每 个 关键 字 和 所 对 应 的 值 独占 一 
行 ， 在 结尾 都 有 一 个 回 车 符 和 换行 符 。 


在 “邮件 正文 ?部 分 是 具体 的 邮件 内 容 ， 但 RFC2822 仅 文 持 ASCII 文 


本 字符 。 


2.MIME 电 子 邮 件 消息 格式 


前 面 介 绍 的 RFC2822 电 子 邮 件 消 息 格 式 只 能 传输 ASCII 码 格式 的 数 
据 ， 一 些 非 英语 字符 消息 ， 像 二 进 制 文件 、 图 像 、 声 音 等 非 文 字 消息 
都 不 能 在 电子 邮件 中 传输 。 这 显然 不 能 满足 当前 多 媒体 时 代 的 电子 邮 
件 通 信和 需求 ， 于 是 开发 了 扩展 的 电子 邮件 消息 格式 标准 
RCF1341， 然 后 在 RFC2045~RFC2049 多 个 RFC 文 档 中 做 了 修改 ， 这 就 


是 MIME 。 


MIME 消 息 可 以 包含 ASCII 文 本 、 图 像 、 首 频 、 视 频 以 及 其 他 应 用 
程序 专用 的 数据 ， 大 大 扩展 了 电子 邮件 消息 的 数据 类 型 。 当 然 ， 目 前 
MIME 消 息 格 式 不 仅 应 用 于 电子 邮件 中 ， 还 在 各 种 浏览 器 中 普遍 应 用 。 
每 个 MIME 类 型 由 两 部 分 组 成 ， 前 面 是 数据 的 大 类 别 ， 如 audio 〈 音 
频 ) 、image (图 像 )、video (视频 ) 等 ， 后 面 定义 具体 的 子 类 。 常 见 
的 MIME 类 型 如 表 11-10 所 示 。 


表 11-10 常见 的 MIME 数据 类 型 
MIEM 类 别 MIME 大 类 /MIME 子 类 


mx 
地 文本 祭 记 本 
下 


RE 
Excel 文档 
PNG 图 像 
au 声音 文件 
VE 
RTX 
2 
TR 


扩展 名 


.xml 


.Xhtml 


.gif 

“Jpeg, .jpg 
.au 

.mid, .midi 
Ta, .ram 
.mpg, .mpeg 
.avi 

.22 


‘tar 


在 电子 邮件 格式 方面 ，MIME 也 继承 了 RFC2822 的 格式 ， 分 为 “ 信 
封 > 和 “邮件 正文 ”两 部 分 。 在 “信封 * 部 分 除了 仍 支 持 RFC2822 中 的 消息 


头 外 ， 另 外 新 增 了 如 表 11-11 所 示 的 消息 头 。 


新 增 的 MIME 消息 头 
MIME-Version 
Content-Type 


Content-Transfer-Encoding 


Content-ID 


Content-Description 


Content-Location 


Content-Base 


表 11-11 新 增 的 MIME 消息 头 
说 明 
标识 使 用 的 MIME 协议 版 本 ， 目 前 都 是 1.0 版 本 
指示 消息 中 的 数据 类 型 ， 以 便 数据 能 被 适当 的 处 理 。 参 见 表 11-10 
指示 消息 中 数据 采用 的 编码 格式 。 可 以 使 用 7bit (7 位 元 的 ASCII 编码 方式 )、 
8bit (8 位 元 的 ASCII 编码 方式 )、binary (二 进 制 编码 方式 )、quoted-printable 和 
base64 中 的 一 种 编码 方式 
用 于 为 “multipartrelated” 组 合 消息 中 的 内 艇 资源 指定 一 个 唯一 标识 号 ， 在 
HTML 格式 的 正文 中 可 以 使 用 这 个 唯一 标识 号 来 引用 该 内 伐 资 源 
指示 邮件 阅读 程序 处 理 数据 内 容 的 方式 ， 有 inline 和 attachment 两 种 标准 方式 ， 
inline 表示 直接 处 理 ， 而 attachment 表示 当做 附件 处 理 。 如 果 将 Content-Disposition 
设置 为 attachment， 在 其 后 还 可 以 指定 filename 属性 
用 于 为 内 人 嵌 资 源 设 置 一 个 URI 地 址 ， 这 个 URI 地 址 可 以 是 绝对 或 相对 的 。 当 使 用 
Content- Location 头 字 段 为 一 个 内 和 嵌 资 源 指 定 一 个 URI 地 址 后 ， 在 HTML 格式 的 正 
文中 也 可 以 使 用 这 个 URI 来 引用 该 内 肯 资 源 
用 于 为 内 做 资源 设置 一 个 基准 路 径 ， 只 有 这 样 ，Content-Location 头 字段 中 设置 的 
URI 才 可 以 采用 相对 地 址 


11.5.3” ”SMTP 请 求 命令 和 应 答 消 息 


SMTP (对 应 RFC2821) 是 目前 应 用 最 广泛 的 提供 电子 邮件 发 送 服 
务 的 应 用 层 协 议 ， 使 用 TCP 端 口号 为 25， 但 它 是 仅 可 以 进行 ASCII 字 符 
传输 的 协议 注意， 这 里 并 不 是 说 电子 邮件 内 容 仅 可 以 是 ASCII 字 符 ， 
而 是 指 SMTP 通 信 时 采用 ASCII 消 息 格式 ) 。 


前 面 提 到 过 ，SMTP 也 是 基于 C/S 模 式 的 ， 它 也 有 对 应 的 客户 端 和 
服务 器 。 但 要 注意 的 是 ， 虽 然 SMTP 服 务 器 功能 仅 是 由 各 种 电子 邮件 服 
务 郁 软件 提供 ， 但 SMTP 客 户 闪 功能 会 可 同时 在 电子 邮件 客户 端 软件 和 
电子 邮件 服务 器 软件 中 提供 (参见 图 11-25) ， 因 为 在 整个 电子 邮件 发 
送 过 程 中 ， 发 件 方 需要 利用 SMTP 客 户 剖 向 自己 的 电子 邮件 服务 器 发 送 
邮件 ， 在 发 件 方 的 电子 邮件 服务 如 把 邮件 传送 到 收 件 方 的 电子 邮件 服 
务 占 的 过 程 中 也 要 利用 SMTP 客 户 端 。 


在 发 送 电 子 邮件 时 ， 源 主机 的 SMTP 客 户 端 程序 要 与 目的 主机 的 
SMTP 服 务 器 程序 的 TCP 25 号 端口 建立 TCP 传 输 连 接 。SMTP 客 户 端 是 
以 一 系列 4 个 字母 的 ASCII 格 式 请 求 命令 向 SMTP 服 务 器 发 送 请 求 消息 
的 ， 而 SMTP 服 务 器 则 是 以 一 些 非常 简单 的 3 位 数字 格式 的 ASCII 消 息 代 
码 进 行 应 答 的 ， 不 同 的 消息 代码 代表 不 同 的 含义 。 


SMTP 邮 件 发 送 过 程 是 在 基于 TCP 25 号 端口 传输 连接 建立 之 后 进行 
的 ， 整 个 邮件 传输 过 程 中 SMTP 客 户 端 和 SMTP 服 务 器 之 间 的 会 话 也 可 
以 分 为 连接 建立 、 邮 件 传输 和 连接 释放 3 个 阶段 。 在 这 3 个 阶段 中 ， 
个 阶段 SMTP 客 户 端 使 用 的 请 求 命令 如 表 11-12 所 示 (目前 可 用 的 是 11 条 
命令 ) 。 每 个 命令 后 面 都 跟 一 个 CRLF ( 回 车 和 换行 标识 符 ) 。SMTP 
服务 器 的 应 答 消 息 如 表 11-13 所 示 。SMTP 服 务 器 针对 SMTP 客 户 端 的 各 
个 请 求 命令 可 以 做 出 的 应 答 消 息 如 表 11-14 所 示 。 


表 11-12 SMTP 客户 端 请 求 命令 


SMTP 会 话 阶 段 请 求 命令 说 明 
后 面 跟 SMTP 客户 端 域名 ， 发 送 方 向 服务 器 标识 用 户 身份 ， 请 求 建立 SMTP 
HELO 应 用 会 话 。 命 令 格 式 为 : HELO (这 里 要 有 空格 ) < 域名 ><CRLF>， 如 HELO 
lycb.com 

与 HELO 功能 一 样 ， 但 支持 SMTP 服务 扩展 的 客户 端 应 该 以 EHLO 命令 开 
EHLO 始 SMTP 会 话 ， 而 不 是 通常 的 HELO 命令 。 命 令 格式 为 : EHLO (这 里 要 有 空 
格 ) < 域名 ><CRLF>， 如 EHLO lycb.com 

后 面 跟 发 件 人 的 电子 邮箱 地 址 ， 向 对 方 服务 器 标识 发 件 人 此 次 所 使 用 的 邮 
MAIL FROM | 箱 地 址 。 命 令 格 式 为 : MAIL FROM:<reverse-path><CRLF>， 其 中 “reverse- 
path” 包 括 发 件 人 的 电子 邮箱 地 址 ， 如 MAIL FROM:<winda@lycb.com> 

后 面 跟 接收 此 电子 邮件 的 邮箱 地 址 ， 向 对 方 服务 器 标识 单个 收 件 人 电子 邮箱 
地 址 。 在 MAIL From 命令 后 面 可 有 多 个 RCPT TO 命令 。 命 令 格式 为 : RCPT 
TO : 其 中 <forward-path><CRLF>， 其 中 forward-path 为 收 件 人 的 电子 邮箱 地 
址 ， 如 grfw@vd.bar.org 

后 面 无 参数 ， 标 识 进行 邮件 传输 初始 化 ， 准 备 开 始 正式 的 邮件 传输 过 程 ， 在 
DATA 内 容 的 最 后 以 CRLF 结尾 ， 标 识 邮 件 传输 结束 。 命 令 格 式 为 : DATA<CRLF>， 
如 DATA 

后 面 跟 要 确认 的 用 户 /电子 邮箱 ， 请 求 服务 器 验证 指定 的 用 户 账户 或 电子 邮 
箱 是 否 存在 ， 考 虑 到 用 户 电 子 邮 箱 账户 安全 性 因素 ， 服 务 器 一 般 禁 止 此 操作 。 
命令 格式 为 : VRFY (这 里 要 有 空格 ) < 校 验 的 字符 串 ><CRLF>， 如 VRFY 
winda(QWiycb.com 

后 面 跟 要 确认 的 电子 邮箱 列表 ， 请 求 服务 器 验证 指定 的 电子 邮箱 列表 是 否 
存在 ， 同 样 考虑 到 用 户 电子 邮箱 账户 安全 性 因素 ， 服 务 器 一 般 禁 止 此 操作 :。 
命令 格式 为 : EXPN (这 里 要 有 空格 ) < 校 验 的 字符 串 ><CRLF>， 如 EXPN 
Example-People 

后 面 跟 要 请 求 帮助 的 命令 ， 请 求 服务 器 提供 帮助 信息 。 命 令 格 式 为 :， HELP 
HELP (这 里 要 有 空格 ) < 要 查询 帮助 信息 的 命令 ><CRLF>，HELP NOOP (就 是 想 
向 服务 器 查询 NOOP 命令 的 帮助 信息 ) 

后 面 无 参数 ， 无 操作 ， 要 求 服 务 器 应 答 OK， 用 于 测试 。 命 令 格 式 为 : 


连接 建立 阶段 


RCPT TO 


VRFY 
邮件 传输 阶段 


EXPN 


NS NOOP<CRLF>， 如 NOOP 
RSE 后 面 无 参数 ， 重 置 SMTP 会 话 ， 当 前 传输 被 取消 。 命 令 格式 为 : RSET<CRLF>， 
如 RSET 
连接 释放 阶段 QUIT 人 终止 邮件 会 话 ， 要 求 服务 器 应 答 OK 。 命令 格式 为 : QUIT<CRLF>， 


表 11-13 SMTP 服务 器 应 答 消 息 


消息 代码 说 明 
200 非 标准 的 成 功 应 答 ， 参 见 RFC876 
211 显示 服务 器 系统 状态 或 系统 帮助 信息 
214 显示 帮助 消息 
220 显示 的 域 SMTP 服务 已 准备 就 绪 
221 显示 的 域 SMTP 服务 关闭 了 传输 信道 
250 操作 正确 完成 ，OK 
251 用 户 非 本 地 ， 将 转发 到 显示 的 域 中 
354 开始 邮件 输入 ， 以 <CRLF>.<CRLF> 结束 ，CRLF 为 回 车 和 换行 标识 乱 
421 指定 域 的 SMTP 服务 不 可 用 ， 关 闭 传输 信道 
450 请 求 的 邮件 操作 未 完成 ， 邮 箱 不 可 用 
451 服务 器 本 地 处 理 进程 出 错 ， 放 弃 请 求 的 邮件 操作 
452 服务 器 系统 存储 空间 不 足 ， 请 求 的 操作 未 执行 
500 语法 错误 ， 命 令 不 可 识别 
501 命令 参数 或 格式 语法 错误 
502 命令 不 可 执行 
503 错误 的 命令 序列 
504 命令 参数 未 执行 
521 显示 的 域 不 接收 邮件 
530 拒绝 访问 
550 邮箱 不 可 用 ， 请 求 的 邮件 操作 不 执行 
551 非 服务 器 本 地 用 户 ， 可 尝试 所 显示 的 域 
552 超出 了 对 应 用 户 的 邮件 存储 分 配 空间 ， 放 弃 请 求 的 邮件 操作 
553 用 户 邮 箱 名 不 允许 ， 不 执行 请 求 的 邮件 操作 
554 邮件 传输 失败 


表 11-14 各 SMTP 请 求 命令 可 能 返回 的 应 答 消息 
SMTP 客户 端 请 求 命令 | 可 能 返回 的 消息 代码 说 明 
请 求 的 邮件 操作 正确 完成 ，OK 


| 500 | 语法 错误 ,命令 不 可 识别 


250 
500 
命令 参数 语法 错误 
0 命令 参数 未 执行 
显示 的 域 没有 接收 邮件 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 传输 信道 
请 求 的 邮件 操作 正确 完成 ，OK 
Eto 不 雪人 
500 


| 500 | 语法 错误 ,命令 不 可 识别 


SMTP 客户 端 请 求 命令 


EHLO 


MAIL 


RCPT 


DATA 


RSET 


可 能 返回 的 消息 代码 
501 


250 
552 


Ee 
mm 
一 


4 


on 


2 


421 
250 
251 


nh 


Ah 
(An 


552 
553 
450 


wn 


1 


5S 


全 


0 


5 


3 


了 


2 


1 


554 


wh 
SS 


503 
421 


SS 


EF 
Le 


nh 


250 
500 


( 续 ) 


说 明 
命令 参数 语法 错误 
命令 参数 未 执行 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 传输 信道 


请 求 的 邮件 操作 正确 完成 ，OK 

超出 用 户 邮 件 存 储 空间 限制 ， 请 求 的 邮件 操作 故 奔 
服务 器 本 地 进程 错误 ， 请 求 的 邮件 操作 放弃 

服务 器 系统 存储 空间 不 是 ， 请 求 的 邮件 操作 未 发 生 
语法 错误 ， 命 令 不 可 识别 

命令 参数 语法 错误 

显示 域 的 SMTP 服务 不 可 用 ， 关 闭 传输 信道 

请 求 的 邮件 操作 正确 完成 ，OK 

非 服务 器 上 本 地 用 户 ， 将 转发 到 显示 的 邮箱 地 址 
邮箱 不 可 用 ， 请 求 的 邮件 操作 未 发 生 

非 服务 器 上 本 地 用 户 ， 将 尝试 显示 的 邮箱 地 址 
超出 用 户 存储 空间 分 配 限 制 ， 请 求 的 邮件 操作 放弃 
用 户 邮 箱 名 不 允许 ， 请 求 的 邮件 操作 未 发 生 

用 户 邮 箱 不 可 用 ， 请 求 的 邮件 操作 未 发 生 

本 地 进程 错误 ， 请 求 的 邮件 操作 放 痉 

服务 器 系统 存储 空间 不 足 ， 请 求 的 邮件 操作 未 发 生 
语法 错误 ， 命 令 不 可 识别 

命令 参数 语法 错误 

错误 的 命令 序列 

显示 的 邮件 域 不 接收 邮件 

显示 域 的 SMTP 服务 不 可 用 ， 关 闭 传输 信道 
开始 邮件 传输 

本 地 进程 错误 ， 请 求 的 邮件 操作 放弃 

和 传输 失败 

下 法 错误 ， 命 令 不 可 识别 

命令 参数 语法 错误 

错误 的 命令 序列 

显示 域 的 SMTP 服务 不 可 用 ， 关 闭 邮 件 接 收 传输 信道 
请 求 的 邮件 操作 正确 完成 ，OK 

超出 用 户 存储 空间 分 配 限 制 ， 请 求 的 邮件 操作 放弃 
服务 器 系统 存储 空间 不 足 ， 请 求 的 邮件 损 作 未 发 生 
非 标准 成 功 应 答 

请 求 的 邮件 操作 正确 完成 ，OK 

语法 错误 ， 命 令 不 可 识别 


SMTP 客户 端 请 求 命令 | 可 能 返回 的 消息 代码 说 明 


命令 参数 语法 错误 
RSET 命令 参数 未 执行 
显示 的 域 SMTP 服务 不 可 用 ， 关 闭 邮件 接收 传输 信道 
请 求 的 邮件 操作 正确 完成 ，OK 
非 服务 器 上 本 地 用 户 ， 将 转发 到 显示 的 邮箱 地 址 
邮箱 不 可 用 ， 请 求 的 邮件 操作 未 发 生 
非 服务 器 上 本 地 用 户 ， 将 尝试 显示 的 邮箱 地 址 
ee 553 用 户 邮箱 名 不 允许 ， 请 求 的 邮件 操作 未 发 生 
语法 错误 ， 命 令 不 可 识别 
501 命令 参数 语法 错误 
502 命令 未 执行 
命令 参数 未 执行 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 邮 件 接收 传输 信道 
250 请 求 的 邮件 操作 正确 完成 ，OK 
邮箱 不 可 用 ， 请 求 的 邮件 操作 未 发 生 
500 语法 错误 ， 命 令 不 可 识别 
EXPN 命令 参数 语法 错误 
命令 未 执行 
504 命令 参数 未 执行 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 邮 件 接收 传输 信道 
系统 状态 或 系统 帮助 应 答 
帮助 消息 
语法 错误 ， 命 令 不 可 识别 
HELP 501 命令 参数 语法 错误 
全 信行 
命令 参数 未 执行 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 邮件 接收 传输 信道 
非 标准 成 功 应 答 
si 请 求 的 邮件 操作 正确 完成 ，OK 
500 语法 错误 ， 命 令 不 可 识别 
显示 域 的 SMTP 服务 不 可 用 ， 关 闭 邮件 接收 传输 信道 
显示 域 的 SMTP 服务 关闭 传输 信道 
Me 500 语法 错误 ， 命 令 不 可 识别 


说 明 ”在 RFC822 中 ，SMTP 还 有 几 条 已 废弃 的 命令 ， 其 中 SEND、 
SOML 和 SAML 现 在 都 直接 用 MAIL FROM 命 令 蔡 代 ，TURN 被 QUIT 命 
令 所 取代 。 


11.5.4 ” SMTP 服务 的 工作 原理 


SMTP 服 务工 作 在 以 下 两 种 情况 ， 一 是 从 在 发 件 方 把 电子 邮件 传输 
到 发 件 方 电子 邮件 服务 器 上 ; 二 是 从 发 件 方 电子 邮件 服务 器 传输 到 收 
件 方 电子 邮件 服务 器 上 。 它 们 都 是 通过 两 端 直接 建立 的 TCP 传 输 连 接 进 
行 电子 邮件 传输 的 ， 接 收 电 子 邮件 的 SMTP 服 务 万 器 使 用 TCP 25 号 端 
量 村 


1.SMTP 邮 件 传输 的 3 个 阶段 


SMTP 客 户 端 使 用 “ 推 ”(push) 的 方式 发 送 电 子 邮 件 ， 每 个 电子 邮 
件 传输 的 SMTP 服 务 应 用 过 程 均 包括 : 连接 建立 〈 这 是 指 SMTP 应 用 会 
话 连接 建立 阶段 ， 不 是 TCP 传 输 连 接 建 立 阶段 ) 、 邮 件 传输 和 连接 释放 
3 个 阶段 〈 注 意 ， 这 3 个 阶段 都 是 在 TCP 传 输 连 接 建 立 后 进行 的 ) 。 有 关 
这 3 个 阶段 所 用 的 请 求 命令 的 应 管 消 恩 可 参见 11.5.3 节 的 介绍 。 下 面 介 
绍 这 3 个 阶段 的 基本 流程 ， 其 中 ,“ 发 件 方 ” 既 可 以 是 发 件 方 主机 ， 也 可 
以 是 发 件 方 电子 邮件 服务 右 ;“ 收 件 方 ” 既 可 以 古 发 件 方 电子 邮件 服务 
二 ， 也 可 以 征收 件 方 电子 邮件 服务 右 ， 具 体 要 视 所 进行 的 电子 邮件 传 
输 过 程 是 从 发 件 方 主机 发 送 到 发 件 方 电子 邮件 服务 器 ， 还 是 从 发 件 方 
电子 邮件 服务 占 到 收 件 方 电子 邮件 服务 峰 而 定 。 


(1) 连接 建立 阶段 


在 SMTP 应 用 会 话 连 接 建 立 阶段 ， 当 发 件 方 有 电子 邮件 发 送 时 ， 首 
先 安装 在 其 主机 中 的 SMTP 客 户 端 程序 会 与 所 配置 的 电子 邮件 服务 器 建 
立 好 基于 TCP 25 号 端口 的 传输 和 连接。 以 后 所 有 的 电子 邮件 传输 过 程 都 
是 在 已 建立 好 的 TCP 连 接 基础 上 进行 的 。 


TCP 传 输 连 接 建 立 好 后 ， 发 件 方 调用 SMTP 客 户 端 服务 发 送 HELO 
命令 ， 后面 跟 发 件 方 的 DNS 域 名 ， 向 收 件 方 表明 自己 的 身份 。 如 果 能 
通过 接收 方 的 身份 验证 ， 那 么 收 件 方 会 返回 一 条 类 似 于 “250 OK” 的 应 
答 消息 ， 表 示 收 件 方 已 接受 会 话 连 接 建 立 请 求 ， 并 建立 好 了 会 话 连 
接 ; 如 果 在 发 送 连 接 请 求 的 HELO 命 令 中 出 现 了 差错 ， 或 者 收 件 方 当前 
SMTP 服 务 不 可 用 ， 则 会 显示 对 应 的 错误 代码 ， 具 体 参 见 表 11-14 。 


(2) 邮件 传输 阶段 


发 件 方 在 发 送 完 HELO 命 令 ， 并 且 收 到 收 件 方 返回 的 250 消 息 代 码 
后 ， 即 表明 收 件 方 已 准备 就 绪 ， 进 入 到 了 邮件 传输 阶段 ， 发 件 方 可 以 
立即 通过 SMTP 客 户 端 发 送 邮 件 。 在 邮件 传输 阶段 ，SMTP 客 户 端 可 以 
使 用 多 个 命令 ， 如 用 MAIL FROM 命令 指示 发 件 人 的 邮箱 地 址 ， 用 
RCPT TO 命令 指示 收 件 人 的 邮箱 地 址 ， 且 可 以 发 送 多 条 RCPT TO 命 
令 包 括 一 个 收 件 人 邮箱 地 址 。 


他 
令 ， 每 条 


他 


当 以 上 两 条 命令 发 送 后 ， 发 件 方 如 条 都 收 到 了 收 件 方 返回 的 类 似 
于 “250 OK” 的 应 管 消息 ， 即 表示 收 件 方 已 正确 执行 了 该 命令 ， 此 时 发 


件 方 STMP 客 户 端 就 可 以 通过 DATA 命 令 进 行 正 式 的 邮件 内 容 传输 了 。 
在 邮件 内 容 全 部 传输 完 后 ， 还 要 传输 一 条 <CRLF>.<CRLF> 消 息 ， 
以 标识 邮件 内 容 的 结束 。 收 件 方 在 收 到 最 后 一 条 消息 后 会 返回 类 似 
于 “250 OK” 的 应 管 消 忌 代 码 。 


如 条 有 另外 一 封 邮 件 要 传输 ， 那 么 它 会 继续 重复 上 述 的 邮件 传输 
过 程 ， 但 无 须 重 复 连 接 建 立 阶 段 。 


(3) 连接 释放 阶段 
当 没 有 邮件 传输 时 ， 发 件 方 SMTP 客 户 端 要 发 送 一 条 QUIT 命 令 结 
束 本 次 SMTP 应 用 会 话 进程 。 正 稍 情况 下 ， 收 件 方 会 返回 一 条 代码 为 
221 的 应 答 消 已 ， 表 示 服 务 右 已 接受 关闭 连接 请 求 ， 释 放 本 次 SMTPY 
用 会 话 连 接 。 


2.SMTP 邮 和 件 传输 流程 示例 


为 了 理解 上 述 邮 件 传输 流程 ， 下 面 仅 以 发 件 方 电子 邮件 服务 万 把 
邮件 传送 到 收 件 方 电子 邮件 服务 紫 的 过 程 为 例 介绍 5SMTP 邮 件 传输 过 程 
中 的 3 个 阶段 。 假 设 发 件 方 电子 邮件 服务 右 的 域名 为 lycb.com， 发 件 人 
的 电子 邮箱 地 址 为 winda@lycb.com， 收 件 方 的 电子 邮件 服务 器 域 名 为 
grfw.com。 基 本 过 程 如 图 11-27 所 示 ( 仅 考 虑 基本 流程 和 正常 情况 下 的 
应 答 代码 ， 不 考虑 各 种 错误 ) 。 


发 件 方 SMTP 收 件 方 SMTP 
服务 天 服务 硕 
HELO lycb.com 


250 grfw.com says hello to jycb.com 连接 建立 阶段 


MAIL FROM: <winda@lycb.com> 


250 sender ok 


RCPT TO: <lina@grfw.com> 


250 recipient ok 
DATA 
邮件 传输 阶段 


354 start mail input, end with <CRLF>.<CRLF> 


<CRLF>.<CRLF> 


250 message accepted 


221 grfw.com closing connection 


| 连接 释放 阶段 


图 11-27 SMTP 邮 和 件 传 输 3 个 阶段 的 基本 请 求 命 令 和 应 管 流程 


下 面 是 一 个 典型 的 SMTP 邮 件 传输 示例 的 脚本 ， 其 中 C 表 示 SMTP 
客户 端 发 送 的 请 求 命令 ，S 代 表 SMTP 服 务 器 返回 的 应 答 消 息 。 其 中 各 


请 求 命 信和 应 管 消 恩 代码 含义 参见 11.5.3 厅 相关 内 容 。 


S:220 foo.com Simple Mail Transfer Service Ready !--- 首先 ，SMTP 服 
务 器 监听 到 TCP25 号 端口 上 有 连接 请 求 ， 建 立 好 相应 的 TCP 连 接 并 通知 SMTP 客 户 端 ， 此 时 说 
明 它 已 做 好 了 准备 ， 可 以 正式 进行 邮件 传输 

C:<open connection> !--- SMTP 客 户 端 打 开 已 建立 好 的 TCP 连 接 
:HELO bar.com 
:250-foo.com greets bar.com 
:250-8BITMIME 
:250-SIZE 
:250-DSN 
:250 HELP 
:MAIL FROM: <Smith@bar.com> 
:250 OK 
:RCPT TO: <Jones@foo.com> 
:250 OK 
:RCPT TO: <Green@foo.com> 
:550 No such user here 
:RCPT TO: <Brown@foo.com> 
:250 OK 
:DATA 
:354 Start mail input;end with<CRLF>.<CRLF> 
:Blah blah blah... 

:...etc,.etc.etc. 


:250 OK 
:QUIT 
:221 foo.com Service closing transmission channel 


OONOONONONONONONONNNWNNWNWO 


11.5.5 ”POP3 请 求 命令 及 应 答 消 息 


上 面 介 绍 的 SMTP 服 务 采用 " 推 ? 的 方式 可 以 把 邮件 发 送 到 发 件 方 目 
己 的 电子 邮件 服务 器 ， 人 然后 由 发 件 方 的 电子 邮件 服务 夯 转 发 到 收 件 方 
的 电子 邮件 服务 右上。 但 是 ， 收 件 方 的 电子 邮件 服务 硕 不 会 通过 SMTP 
服务 再 把 邮件 推送 到 收 件 人 主机 上 ， 因 为 收 件 人 并 不 知道 什么 时 候 有 
人 发 邮件 给 他 ， 也 不 可 能 24 小 时 在 线 ， 即 不 可 能 随时 接收 。 我 们 希望 
的 是 像 发 件 人 发 送 邮 件 那样 ， 在 需要 的 时 候 随 时 进行 接收 。 这 时 就 得 
靠 POP3 这 样 具有 “ 拉 ” (pull) 功能 的 邮件 服务 了 。 


POP3 (对 应 RFC1939) 是 POP (对 应 RFC918) 的 第 3 个 版 本 ， 解 
决 了 POP 服务 器 在 用 户 阅 读 了 某 封 邮件 后 即 删除 该 邮件 的 不 足 ，POP3 
服务 器 允许 用 户 把 邮件 存储 在 邮件 服务 器 上 。POP3 人 允许 用 户 从 服务 器 
上 把 邮件 存储 到 本 地 主机 〈 即 自己 的 计算 机 ) 上 ， 同 时 根据 客户 端的 
需要 删除 或 保存 在 电子 邮件 服务 器 上 的 邮件 。 如 果 把 SMTP 服 务 器 称 
为 "发送 邮件 服务 器 ”〈 用 来 发 送 邮件 ) ， 则 POP3 服 务 器 就 可 以 称 为 “ 接 
收 邮件 服务 器 ”( 用 来 接收 邮件 ) 。 


POP3 也 是 工作 在 C/S 模 式 上 的 ， 其 中 POP3 客 户 端 位 于 安装 了 各 种 
电子 邮件 客户 端 软件 的 用 户主 机 上 ， 而 POP3 服 务 器 则 位 于 安装 了 各 种 
电子 邮件 服务 器 软件 的 服务 器 主机 上 ， 参 见 图 11-25 所 示 的 电子 邮件 系 
统 结构 。POP3 客 户 端 和 POP3 服 务 器 之 间 的 通信 是 在 TCP 110 号 端口 所 


建立 的 TCP 传 输 连接 基础 之 上 的 。POP3 服 务 器 会 时 刻 在 TCP 110 端 口上 
进行 监听 ， 发 现 有 POP3 客 户 连 接 请 求 即 做 出 相应 的 应 答 。 但 POP3 服 务 
仅 用 于 用 户 从 自己 的 电子 邮件 服务 器 上 获取 电子 邮件 ， 不 像 SMTP 服 务 
那样 涉及 两 个 过 程 ， 相 对 来 说 较为 简单 。 


1.POP3 请 求 命 令 


与 SMTP 服 务 一 样 ，POP3 应 用 服务 通信 也 是 先 由 POP3 客 户 端 发 出 
请 求 命令 ， 然 后 POP3 服 务 絮 返回 应 管 消 已。 在 通过 POP3 服 务 器 的 映 份 
验证 后 ，POP3 客 户 端 才 可 进行 邮件 接收 或 者 从 POP3 服 务 器 删除 邮件 等 
操作 。 但 POP3 同 样 是 只 支持 ASCII 的 通信 交互 方式 ， 因 此 ， 无 论 是 
POP3 客 户 端 发 出 的 请 求 命令 ， 还 是 POP3 服 务 器 向 POP3 客 户 端 返回 的 
应 答 消 息 ， 都 是 ASCII 码 格式 。 


POP3 客 户 端 发 出 的 请 求 命令 是 3~4 个 字母 的 ASCII 码 格式 。 每 个 
POP3 请 求 命令 由 一 个 命令 关键 字 和 一 些 参数 组 成 ， 各 部 分 之 间 以 空格 
分 隔 ， 每 个 参数 长 度 可 达 40 个 字符 ， 所 有 命令 均 以 一 个 <CRLE > 标志 


符 结 束 。 具 体 命令 说 明 如 表 11-15 所 示 ( 共 12 条 ) 


USER name 


PASS string 


APOP name digest 


STAT 


LIST [msg] 
RETR msg 
DELE msg 


NOOP 
RSET 


TOP msg lines 


UIDL [msg] 


QUIT 


表 11-15 POP3 客户 端 请 求 命令 


指示 用 户 访 问 POP3 邮件 服务 器 时 所 用 的 用 户 邮 箱 账 户 名 (不 包括 域名 部 分 )， 它 与 下 面 
PASS 命令 指出 的 账户 和 密码 一 起 作为 访问 POP3 服务 器 时 进行 身份 验证 的 凭据 。 如 USER 
winda 

指示 用 户 访问 POP3 邮件 服务 器 时 所 用 的 用 户 邮箱 账户 和 密码 ， 它 与 上 面 的 USER 命令 
指出 的 账户 和 密码 一 起 作为 访问 POP3 服务 器 时 进行 身份 验证 的 凭据 

指示 用 户 访问 POP3 服务 器 所 使 用 的 加 密 密 钥 (避免 以 明文 方式 在 网 上 传输 密码 )，name 
参数 是 用 户 邮 箱 账户 名 ，digest 为 通过 MD5 协议 加 密 后 的 密 铀 

查询 用 户 自 己 的 邮箱 统计 信息 。 最 开始 显示 的 是 “OK”， 然 后 空 一 格 后 再 显示 邮件 的 总 
数 ， 再 空 一 格 显 示 所 有 邮件 的 大 小 等 内 容 

请 求 查 看 指定 (选择 msg 参数 时 ) 或 者 全 部 (不 选择 msg 参数 时 ) 邮件 汇总 信息 。 服 务 
器 应 答 后 会 显示 每 个 列 出 的 邮件 的 邮件 号 和 对 应 的 邮件 大 小 

请 求 接收 指定 邮件 

请 求 给 指定 邮件 做 删除 标记 。 做 了 删除 标记 的 邮件 不 会 真正 被 删除 ， 因 为 只 有 在 POP3 
客户 端 发 出 QUIT 命令 后 才 会 真正 删除 这 些 做 了 删除 标记 的 邮件 

无 操作 ， 用 于 检测 POP3 客户 端 与 POP3 服务 器 的 连接 情况 ， 仅 用 于 测试 

恢复 所 有 邮件 均 为 无 删除 标记 ， 也 就 是 清除 所 有 通过 DELE 命令 所 做 的 邮件 删除 标记 

请 求 查看 指定 邮件 (通过 msg 参数 指定 ) 中 指定 行 (通过 lines 参数 指定 ) 前 的 内 容 

请 求 查看 指定 (选择 msg 参数 时 ) 或 所 有 (不 选择 msg 参数 时 ) 邮件 的 内 容 ， 但 不 能 查 
看 有 删除 标记 的 邮件 

用 户 邮件 接收 完成 ， 请 求 结束 本 次 POP3 应 用 会 话 。 如 果 此 时 某 邮 件 消息 打上 了 删除 标 
记 ， 则 服务 器 会 删除 该 邮件 (不 在 服务 器 上 保留 备份 ) ， 如 果 在 删除 邮件 时 发 生 了 错误 ， 则 
可 能 会 有 一 些 或 者 全 部 已 标记 为 删除 的 邮件 均 不 会 被 删除 。 无 论 删 除 是 否 成 功 ， 服 务 器 均 
会 释放 对 应 的 POP3 应 用 会 话 连接 ， 不 允许 进行 访问 ， 同 时 关闭 对 应 的 TCP 连接 


2.POP3 应 答 消 息 


POP3 服 务 器 对 POP3 客 户 端 请 求 命令 的 应 管 消息 是 由 一 个 状态 码 和 


一 些 附 加 信息 


百 / 心 ， 


组 成 的 。 应 答 消 轧 可 以 占 多 行 ， 


但 每 行 的 最 后 必须 加 < 


CRLF > ， 而 整个 消息 的 结束 要 以 <CRLF>.<CRLF> 表 示 。 


大 多 数 POP3 请 求 命 令 (有 些 命令 只 可 能 返回 一 种 状态 码 ) 都 可 能 
返回 两 种 不 同 的 应 答 状 态 码 : “+OK” (确定 ) 和 “-ERR”( 错 误 ) 。 注 
意 ,，“OK” 和 “ERR” 必 须 大 写 。 表 11-15 中 的 POP3 客 户 端 请 求 命令 可 能 返 
回 的 应 答 消 息 如 表 11-16 所 示 (注意 ， 其 中 返回 的 应 答 消 息 仅 为 示 
例 ) 。 


POP3 客户 端 
请 求 命令 


USER 


PASS 


APOP 


STAT 


LIST 


RETR 


DETE 


NOOP 
REST 


TOP 


UIDL 


QUIT 


表 11-16 POP3 服务 器 应 答 消 息 


POP3 服务 器 应 答 


消息 示例 


+OK mrose is a valid mailbox 
-ERR sorry, no mailbox for frated here 


+OK mrose's maildrop has 2 messages 
(320 octets) 
-ERR maildrop already locked 


+OK maildrop has 1 message (369 
octets) 


-ERR permission denied 
+OK 2 320 


+OK 2 messages (320 octets) 


-ERR no such message, only 2 messages 
in maildrop 


+OK 0 has 2 messages (320 
| 


-ae 一 no such message 
+OK 2 QhdPYR:00WBw1Ph7x7 


-ERR no such message, only 2 messages 
in maildrop 


+OK dewey POP3 server signing off 


正确 ， 
错误 ， 
正确 ， 


说 明 
该 用 户 邮箱 可 用 
没有 指定 的 邮箱 用 户 
并 返回 对 应 用 户 邮 箱 的 基本 统计 信息 ， 包 括 


邮件 数 和 邮件 总 体 大 小 


错误 ， 
正确 ， 


指定 用 户 邮 箱 已 被 锁定 
并 返回 对 应 用 户 邮箱 的 基本 统计 信息 ， 包 括 


邮件 数 和 邮件 总 体 大 小 


洪 误 ， 


日 些 误 ， 
确认 ， 
本 


错误 ， 
正确 ， 


错误 ， 
确认 ， 


吴 ， 没 有 对 应 邮件 


拒绝 访问 
返回 对 应 用 户 邮 箱 邮 件数 和 邮件 总 体 大 小 
返回 对 应 邮件 的 邮件 号 和 大 小 ， 并 开始 接收 
没有 对 应 邮件 号 的 邮件 
返回 对 应 邮件 大 小 
号 的 邮件 
指定 邮件 已 标记 为 删除 
指定 邮件 已 标记 为 删除 
无 返回 
返回 已 恢复 删除 标记 的 邮件 数 和 邮件 总 体 大 


返回 指定 行 的 邮件 内 容 
没有 对 应 邮件 内 容 

返回 对 应 邮件 号 的 唯一 ID 号 
没有 对 应 邮件 号 的 邮件 


对 应 服务 器 正在 释放 POP3 应 用 会 话 连接 


11.5.6 ”POP3 服 务 的 工作 原理 


从 理论 上 来 讲 ， 也 可 以 把 整个 POP3 邮 件 接收 过 程 分 为 “连接 建 
立 ”、“ 邮 件 接 收 " 和 “连接 释放 ”这 3 个 阶段 。 它 们 都 是 在 基于 与 POP3 服 
务 右 TCP 110 端 口 建立 TCP 传输 连接 的 基础 上 进行 的 ， 也 就 是 在 进行 正 
式 的 邮件 接收 前 ，POP3 客 户 端 必须 与 POP3 服 务 右 的 TCP 110 端 口 建立 
传输 连接 (POP3 服 务 器 会 时 刻 监听 TCP 110 端 口 ， 一 旦 有 连接 请 求 马 上 
做 出 应 答 ) 。 


连接 建立 阶段 其 实 就 是 POP3 客 户 端 向 POP3 服 务 絮 发 出 身份 验证 请 
求 ， 给 出 用 户 名 和 密码 的 阶段 ， 包 括 表 11-15 所 示 的 USER、PASS 和 


APOP 这 几 个 请 求 命令 。 


邮件 接收 阶段 是 用 户 在 进行 邮件 接收 时 进行 的 各 种 操作 ， 包 括 表 
11-15 中 除 USER、PASS、APOP 和 QUIT 这 4 个 命令 外 的 其 他 所 有 命令 。 


连接 释放 阶段 是 POP3 客 户 并 在 接收 完全 部 邮件 ， 或 者 进行 完 所 有 
需要 的 操作 后 释放 本 次 POP3 应 用 会 话 连 接 的 过 程 ， 包 括 的 请 求 命 令 是 
QUIIT 。 


图 11-28 是 一 个 典型 的 POP3 邮 件 接收 的 基本 流程 示例 ， 对 应 的 代码 
脚本 如 下 所 示 ， 其 中 C 代 表 POP3 客 户 端 发 送 的 请 求 命 令 ，S 代 表 POP3 


S 


服务 夯 返 回 的 应 答 消 轧 。 其 中 各 请 求 俞 令 和 应 答 消 妃 代 码 含义 参见 
5. 


11.5.5 节 相关 内 容 。 


S:+0K POP3 server ready<1896.697170952@dbc.mtview.ca.us> !--- 首 
EE，POP3 服 务 器 监 昕 到 TCP 110 号 端口 上 有 连接 请 求 ， 建 立 好 相应 的 TCP 连 接 并 通知 POP3 客 
户 端 ， 此 时 ， 说 明 它 已 做 好 了 准备 ， 可 以 正式 进行 邮件 接收 
:<open connection> !--- POP3 客 户 端 打开 已 建立 好 的 TCP 连 接 
:USER winda 
:+OK winda is a real hoopy frood 
:PASS 123456 
:+OK winda's maildrop has 2 messages(320 octets) 
:STAT 
:+OK 2 320 
:LIST 
:+OK 2 messages(320 octets) 

:1 120 
:2 200 


he 


:RETR 1 
:+OK 120 octets 
:<the POP3 server Sends message 1> 


:DELE 1 

:+OK message 1 deleted 

:RETR 2 

:+OK 200 octets 

:<the POP3 server sends message 2> 


:DELE 2 

:+OK message 2 deleted 

:QUIT 

:+OK dewey POP3 server signing off(maildrop empty) !--- 邮件 接收 
完成 ， 邮 件 投递 箱 为 空 


OONONNNAONONNNOONNNNONONONWNONWNOO 


POP3 客 户 端 POP3 服 务 器 
USER winda 


+OK winda is a real hoopy frood 
PASS 123456 连接 建立 阶段 
+OKwinda’s maildrop has 2 messages (320 octets) 
STAT 
+OK 2 320 


LIST 


+OK 2 messages (320 octets) 邮件 接收 阶段 
RETR 1 
+OK 120 octets <the POP3 server sends message 1> 
DELE 1 


+OK message 1 deleted 


QUIT 
连接 释放 阶段 
OK dewey POP3 server signing off (maildrop empty) 


图 11-28 POP3 邮 件 接收 基本 流程 示例 


11.5.7 IMAP4 简 介 


在 接收 邮件 方面 ， 除 了 前 面 介绍 的 POP3 外 ， 目 前 还 有 一 种 功能 
强大 ， 但 也 更 复杂 的 协议 一 一 IMAP4 (Internet Message Access 
Protocol 4， 互 联网 消息 访问 协议 第 4 版 ) 。IMAP4 也 是 采用 C/S 工 作 模 
式 的 。IMAP4 服 务 器 工作 在 TCP 143 号 端口 。 目 前 绝 大 多 数 电子 邮 件 
客户 端 程序 都 同时 支持 POP3 和 IMAP4， 如 Outlook、Windows Mail、 


Outlook Express ~、 Foxmail ~ Entourage ~、 Mozilla Thunderbird 和 Eudora 


4 。 
于 


与 POP3 类 似 ，IMAP4 (对 应 RFC3501) 也 是 为 用 户 提 供 邮 件 接收 
服务 的 (发 送 邮 件 同 样 是 使 用 SMTP) 。IMAP4 改 进 了 POP3 的 不 足 ， 
具体 来 说 ， 它 有 以 下 几 方 面 的 特性 : 


(1) 文 持 服务 器 端 邮件 副本 存储 


在 默认 情况 下 ，POP3 客 户 剖 程序 在 将 电子 邮件 下 载 到 计算 机 上 
后 ， 会 从 服务 器 上 删除 所 有 已 下 载 的 电子 邮件 。 而 IMAP4 却 可 以 在 电 
子 邮件 服务 器 上 保留 下 载 的 邮件 的 副本 ， 这 样 就 可 以 从 多 台 计 算 机 访 
问 保 存在 服务 器 上 的 同一 封 电子 邮件 。 


(2) 支持 离线 、 在 线 和 断 线 3 种 访问 方式 


POP3 仪 支持 离线 访问 方式 ， 客 户 端 只 会 与 POP3 服 务 器 连接 一 上 段 
时 间 ， 直 到 它 下 载 完 所 有 新 信息 ， 客 户 端 即 断 开 连接 ， 而 IMAP4 可 以 
同时 支持 离线 、 在 线 和 断 线 3 种 访问 方式 。 


在 离线 方式 中 ， 虽 然 IMAP4 客 户 端 软 件 也 是 把 邮件 存储 在 本 地 硬 
盘 上 ， 但 IMAP4 提 供 的 摘要 浏览 功能 可 以 让 用 户 通 过 移 阅 读 完 所 有 的 
邮件 到 达 时 间 、 主 题 、 发 件 人 、 大 小 等 信息 后 才 做 出 是 否 下 载 的 决 
定 。 也 就 是 说 ， 用 户 不 必 等 所 有 的 邮件 都 下 载 完 毕 后 才 知 道 究竟 邮件 
里 都 有 些 什么 。 如 采用 户 根 据 摘 要 信息 承 可 以 判断 荣 些 邮件 对 他 来 说 
讲 无 用 处 ， 那 么 他 可 以 直接 在 服务 右上 把 这 些 邮 件 删除 ， 而 不 必 当 费 
宝贵 的 上 网 时 间 。 在 在 线 方式 中 ，IMAP4 客 户 端 可 以 通过 Web 浏 览 器 
来 访问 IMAP4 服 务 右 上 的 邮件 ， 不 需要 像 离线 模式 那样 把 邮件 下 载 到 
本 地 才能 阅读 。 在 断 线 方式 中 ，IMAP4 客 户 软件 把 用 户 选 定 的 消息 和 
附件 复制 或 缓存 到 本 地 人 磁盘 上 ， 并 把 原始 副本 留存 在 邮件 服务 大 上， 
当 以 后 用 户 重 新 连接 IMAP4 服 务 器 时 ， 这 些 邮 件 又 可 以 与 服务 器 进行 
再 同步 ， 显 示 全 部 的 邮件 内 容 。 


(3) 支持 多 个 客户 同时 连接 到 一 个 邮箱 


POP3 在 同一 时 间 只 能 允许 一 个 用 户 活 动 连接 ， 而 IMAP4 人 允许 同一 
时 间 不 同 用 户 对 同一 邮箱 的 多 个 用 户 活 动 连接 ， 并 且 提 供 了 一 种 机 制 
能 让 客户 感知 当前 连接 到 这 个 邮箱 的 其 他 用 户 的 操作 。 这 对 于 多 个 用 
户 使 用 同一 邮箱 时 非常 有 用 ， 如 一 个 项 目 组 可 能 使 用 同一 个 邮箱 来 进 


行 邮 件 收发 ， 但 不 同 成 员 可 能 会 同时 上 网 查看 邮箱 中 各 目 所 需 的 邮 
I 


(4) 文 持 选择 性 获取 


如 果 用 户 的 IMAP 客 户 端 软 件 完整 文 持 IMAP4 rev1 的 话 ， 则 用 户 还 
可 以 享受 选择 性 下 载 附 件 的 服务 ， 既 可 以 只 下 载 正 文 ， 也 可 以 下 载 部 
分 附件 或 全 部 附件 。 例 如 ， 在 一 封 邮 件 中 含有 三 个 附件 ， 但 其 中 只 
一 个 附件 是 用 户 所 需要 的 ， 这 时 用 户 可 以 只 下 载 那 一 个 需要 的 附件 ， 
节省 了 下 载 其 余 两 个 附件 的 时 间 。 


(5) 支持 在 用 户 邮 箱 上 创建 、 管 理 多 个 文件 夹 功 能 


在 POP3 中 ， 每 个 用 户 邮 箱 只 能 有 几 个 默认 的 文件 夹 〈 如 草稿 箱 、 
发 件 箱 、 收 件 箱 、 垃 圾 箱 等 ) ， 不 可 新 建 其 他 文件 夹 ， 也 不 可 删除 原 
来 的 这 些 默 认 文件 夹 ， 但 在 IMAP4 服 务 器 上 ， 可 以 在 每 个 默认 文件 夹 
下 创建 多 个 新 的 子 文件 来 ， 并 且 可 以 对 各 个 邮箱 文件 夹 进行 重 命名 ， 
或 进行 删除 操作 。 这 样 ， 用 户 束 可 以 对 接收 或 者 发 送 的 邮件 分 门 别 类 
地 进行 管理 ， 风 像 本 地 位 盘 的 文件 夹 管理 一 样 。 


(6) 文 持 服务 器 搜索 


IMAP4 提 供 了 一 种 可 以 使 客户 站 在 服务 上 肿 上 搜索 符合 多 个 标准 的 
言 思 的 机 制 ， 相 当 于 在 本 地 磁盘 中 进行 文件 搜索 。IMAP4 的 搜索 功能 


很 强大 ， 不 仅 可 以 基于 邮件 标题 进行 搜索 ， 还 可 基于 邮件 信封 中 其 他 
部 分 ， 甚 至 邮件 正文 内 容 进 行 搜索 。 这 样 ， 客 户 端 无 须 下 载 邮 箱 中 所 
有 信息 整 可 以 完成 这 些 搜 索 。 


(7) 文 持 客户 端 和 服务 器 间 的 拖 动 操作 


一 般 的 IMAP4 客 户 端 软件 都 支持 邮件 在 本 地 文件 夹 和 服务 器 文件 
夹 的 随意 拖 动 ， 这 样 可 以 让 用 户 轻松 地 把 本 地 硬盘 中 的 文件 存放 到 服 
务 器 上 ， 然 后 在 需要 的 时 候 同样 方便 地 取 回来 ， 所 有 的 功能 仅 需 要 一 
次 鼠标 拖 放 的 操作 就 可 以 实现 ， 就 像 在 网 络 中 不 同 主机 间 的 文件 操作 
一 样 简单 。 


说 明 ”因为 IMAP4 相 对 来 说 更 为 复杂 ， 且 目前 POP3 可 以 满足 大 多 
数 电 子 邮 件 用 户 的 需求 ， 所 以 在 此 不 对 IMAP4 进 行 更 加 详细 的 介绍 。 


